로그인

검색

Algorithm
2012.08.13 10:07

동적 프로그래밍

조회 수 3235 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄

1. 팩토리얼 계산하는 문제


분할 정복

int factorial(int n)
{
if(n==1) return 1; 
else return n*factorial(n-1);

동적 프로그래밍

int factorial(int n)
{
int i;
int product = 1;
for(i=1;i<=n;i++) product *= i;
return product;
}


2. 피보나치 수열 구하는 문제


f(n) = f(n-1) + f(n-2) 인 규칙을 가지는 피보나치 수열 계산


분할 정복

int fibonacci(int n)
{
if(n==1 || n==2) return 1;
else return fibonacci(n-1) + fibonacci(n-2);
}


동적 프로그래밍

int fibonacci(int n)
{
int i,series;
int last1 = 1;
int last2 = 1;

if(n==1 || n==2) return 1;
else
{
for(i=2; i<n; i++)
{
series = last1 + last2;
last1 = last2;
last2 = series;
}

return sereis;
}
}


3. 이항 계수 구하는 문제


nCr = n-1Cr-1 + n-1Cr 공식 이용하여 이항 계수 계산


분할 정복

int bincoeff(int n, int k)
{
if(k==0 || k==n) return 1;
else return bincoeff(n-1, k-1) + bincoeff(n-1, k);
}

동적 프로그래밍

int bincoeff(int n, int k)
{
int i,j;
int B[0...n][0...n];
for(i=0; i<n; i++)
for(j=0; j<min(i,k); j++)
if(j==0 || j==i) B[i][j] = 1;
else B[i][j] = B[i-1][j-1] + B[i-1][j];
}


동적 프로그래밍으로 하는 경우 중복하여 계산하게 되는 경우를 막을 수 있으므로 계산시간이 더 빠르다.


?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 Tool/etc Programming 게시판 관련 2 MoA 2014.11.01 15452
58 Tool/etc AWS 망 분리하기 OBG 2022.09.06 2798
57 Tool/etc AWS VPC 피어링 OBG 2022.11.03 3035
56 Graphic ASCII 3D 렌더러 만들기 OBG 2024.06.03 2276
55 Library AS3 Code Library MoA 2013.10.11 6817
54 LLM Anthropic, LLM의 내부를 이해하는데 있어 상당한 진전을 보임 OBG 2024.06.03 2257
53 LLM AI-hub 공공데이터를 활용하여 한국어-영어 번역 LLM 만들기 OBG 2025.01.14 1566
52 Web Address Bar Install for Progressive Web Apps on the Desktop OBG 2021.12.15 2461
51 LLM A Beginner's Guide to Prompt Engineering with GitHub Copilot OBG 2024.04.04 1755
50 Algorithm 2048게임 높은 점수 얻기 위한 알고리즘 MoA 2014.03.29 3153
49 Python 2048 Game in Python OBG 2022.09.22 2935
48 Site 2024년 가장 조회수 높은 소프트웨어 엔지니어링 발표들 OBG 2025.02.18 1403
47 Tool/etc 2016년에 자바스크립트를 배우는 기분 MoA 2016.12.27 2604
46 Site 10 Useful/Fun/Weird Github Repos You Have to Play Around With OBG 2023.12.28 2794
45 API/MFC #pragma MoA 2013.07.28 2615
44 Tool/etc "Node.js를 떠나며" - express를 만든 TJ의 글 OBG 2022.06.23 2398
43 Deeplearning [한빛미디어] 머신러닝·딥러닝 도서 선택 가이드 OBG 2023.06.11 2646
42 Python [첫게임 만들기] 9. 사운드 file MoA 2013.11.21 3539
41 Python [첫게임 만들기] 8. Win or Lose file MoA 2013.11.21 3205
40 Python [첫게임 만들기] 7. 게임 정보 표시 file MoA 2013.11.21 3923
39 Python [첫게임 만들기] 6. 적을 해치우자 1 file MoA 2013.11.21 3717
Board Pagination Prev 1 ... 6 7 8 9 10 11 12 13 14 15 Next
/ 15