메뉴 건너뛰기

OBG

Programming

Algorithm
2012.08.13 10:07

동적 프로그래밍

조회 수 524 추천 수 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 1958
187 Tool/etc UI Guidelines MoA 2014.03.11 537
186 Tool/etc 자바스크립트 물리엔진 ㄷㄷ MoA 2014.03.10 637
185 API/MFC 다이얼로그 기반에서 메뉴 내용이 갱신 안되는 문제 해결 MoA 2014.02.13 979
184 Python 파이썬에서 C모듈 사용하기 MoA 2014.02.10 1931
183 Library CSpreadSheet MoA 2014.02.03 395
182 Reversing 워게임 사이트 정리 MoA 2014.01.27 1308
181 C/C++ RAND_MAX 2 MoA 2014.01.19 413
180 Python OpenCV 이용한 템플릿 매칭 MoA 2014.01.16 1267
179 Tool/etc Quake 3 source code and review MoA 2014.01.15 415
178 Python 화면 캡쳐 소스 MoA 2014.01.14 986
177 C/C++ __FILE__ __LINE__ __FUNCTION__ 등 매크로 MoA 2014.01.02 618
176 Tool/etc 유용한 라이브러리 소개 MoA 2013.12.27 891
175 Python Embedding Python in C/C++ MoA 2013.12.23 413
174 Python SciPy and NumPy MoA 2013.12.23 625
173 API/MFC 다국어를 위한 StringTable, LoadString 1 MoA 2013.12.22 2429
172 API/MFC WTL 정리 file MoA 2013.12.22 961
171 API/MFC GetLastInputInfo 함수 MoA 2013.12.06 453
170 Python [GUI] wxPython에서 에러메시지 콘솔로 보는 법 MoA 2013.12.03 368
169 Python [GUI] wxPython 기본 프로그램 file MoA 2013.11.30 672
168 Python [GUI] Tkinter, wxPython MoA 2013.11.27 661
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 15 Next
/ 15
위로