글
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 |