글
Dynamic Programming - Make Change Problem
N 개 타입의 동전으로 어떠한 금액을 만드는 것과 관련된 문제이다.
여기서 몇 가지 문제를 생각할 수 있는데,
1. Frobenius coin problem
이 문제는 NP-hard 문제로, GCD(최대공약수)가 1인 N 개 타입의 동전으로 만들 수 없는,
가장 큰 수를 찾는 문제이다. 이 수를 Frobenius(프로베니우스) number 라 한다.
하지만 N이 1,2,3 일 때는 다항시간에 찾을 수 있는 공식이 나와있다.
더 자세
한 내용은 위키피디아 http://en.wikipedia.org/wiki/Coin_problem 참고.
2. N 개 타입의 동전으로 어떠한 금액을 만들 때, 가장 적은 수의 동전을 사용했을 때의 동전의 수.
(단 N >= 1 이고 N[1] = 1 )
요 문제는 Greedy 한 방법으로 풀어도 되지만, DP 방법으로 풀 수도 있다.
3. N 개 타입의 동전으로 어떠한 금액을 만들 때, 가능한 동전 조합의 경우의 수를 구하는 경우.
(단 N >= 1 이고 N[1] = 1 )
이 문제는 약간 어려웠던거 같다. 그냥 생각만으로는 잘 안되서,
아주 간단한 케이스를 가지고 종이에 적어가면서 확인했다.
조합의 수를 구하는 문제는 좀 헷갈리긴 했지만,
생각을 좀 해보고, 간단한 케이스를 확인해 보면서 찾을 수 있었다.
'프로그래밍' 카테고리의 다른 글
| Dynamic Programming - Building Bridges, Balanced Partition. (2) | 2012.08.06 |
|---|---|
| Dynamic Programming - Longest Increasing Subsequence, Box Stacking (0) | 2012.08.03 |
| Dynamic Programming - Maximal Contiguous Subsequent Sum Problem (2) | 2012.07.31 |
| Dynamic Programming - Knapsack Problem (0) | 2012.07.31 |
| Eclipse CDT + Cygwin 으로 C/C++ 개발 환경 설정 관련... (0) | 2012.06.29 |
글
Dynamic Programming - Maximal Contiguous Subsequent Sum Problem
문제) N 개의 실수 A(1) ~ A(N)이 있을 때, 연속된 수 A(i) ... A(j)의 합이 최대가 되는 값을 구하라.
솔직히 Brute Force 방식으로 풀어도 O(N^3)의 복잡도를 가지므로,
NP-Complete 한 문제는 아니다.
하지만 D.P 연습으로 공부를 하는 거니깐.
D.P 문제 중에는 난이도가 낮은 문제가 아닐까?
'프로그래밍' 카테고리의 다른 글
| Dynamic Programming - Building Bridges, Balanced Partition. (2) | 2012.08.06 |
|---|---|
| Dynamic Programming - Longest Increasing Subsequence, Box Stacking (0) | 2012.08.03 |
| Dynamic Programming - Make Change Problem (2) | 2012.08.01 |
| Dynamic Programming - Knapsack Problem (0) | 2012.07.31 |
| Eclipse CDT + Cygwin 으로 C/C++ 개발 환경 설정 관련... (0) | 2012.06.29 |
글
Dynamic Programming - Knapsack Problem
- Knapsack Problem
Dynamic Programming을 공부하면서,
(정말 정말 너무나 쉬운) Fibonacci 수열의 값을 구하는 예를 제외하고,
가장 많이 이용되는 예가 아닐까?
열 마디 설명보다 그림이 이해하기 쉬우므로, 부담없이 인용할 수 있는 위키피디아 그림을 가져왔다.
|
위 그림과 같이 15kg까지 담을 수 있는 배낭에
각각 Value와 Weight를 가진 N 종류 타입의 상자들을 담았을 때,
Max Value가 되는 값이 얼마인가? 를 구하는 문제이다.
Knapsack Problem에는 3가지 종류가 있다.
이 구분은 사용가능한 N 종류 타입의 아이템의 갯수에 따라 나뉜다.
(위 그림으로 치자면 상자의 각 타입의 상자가 몇 개씩 있느냐?)
1. 0-1 Knapsack Problem : N 개의 타입의 아이템이 1개씩 있음.
2. Bounded Knapsack Problem : N 개의 타입의 아이템이 x(임의의 갯수)개씩 있음.
3. Unbounded Knapsack Problem : N 개의 타입의 아이템의 갯수 제한이 없음.
기본적인 해결 아이디어는 동일하다.
하지만 종류에 따라 아이디어를 조금 간소화 시킬 수 있다.
3가지 방법에 대해 일반적으로 사용할 수 있는 Knapsack 소스는 다음과 같다.
결론
다시 한번봐도 어렵긴 마찬가지다.
여러가지 D.P 문제들을 보고 익숙해지길 바라는 수 밖에.
(추가사항)
Knapsack Problem 중에 아이템을 쪼갤수 있는 Case의 경우는,
Value/Weight 가 높은 순으로 Greedy 한 방법을 통해 해결할 수 있다.
'프로그래밍' 카테고리의 다른 글
| Dynamic Programming - Building Bridges, Balanced Partition. (2) | 2012.08.06 |
|---|---|
| Dynamic Programming - Longest Increasing Subsequence, Box Stacking (0) | 2012.08.03 |
| Dynamic Programming - Make Change Problem (2) | 2012.08.01 |
| Dynamic Programming - Maximal Contiguous Subsequent Sum Problem (2) | 2012.07.31 |
| Eclipse CDT + Cygwin 으로 C/C++ 개발 환경 설정 관련... (0) | 2012.06.29 |