알고리즘/코딩테스트 공부
10-4. 동전 교환(냅색 알고리즘)
YG - 96년생 , 강아지 있음, 개발자 희망
2022. 3. 26. 09:53
냅색 알고리즘이란?
배낭 문제는 조합 최적화의 유명한 문제이다. 간단하게 말하면, 한 여행가가 가지고 가는 배낭에 담을 수 있는 무게의 최댓값이 정해져 있고, 일정 가치와 무게가 있는 짐들을 배낭에 넣을 때, 가치의 합이 최대가 되도록 짐을 고르는 방법을 찾는 문제이다.
문제
다음과 같이 여러 단위의 동전들이 주어져 있을때 거스름돈을 가장 적은 수의 동전으로 교환 해주려면 어떻게 주면 되는가? 각 단위의 동전은 무한정 쓸 수 있다.
풀이
function solution(m, coin) {
let answer = 0;
let dy = Array.from({ length: m + 1 }, () => 1000);
dy[0] = 0;
for (let i = 1; i < coin.length; i++) {
for (let j = coin[i]; j <= m; j++) {
dy[j] = Math.min(dy[j], dy[j - coin[i]] + 1);
}
}
answer = dy[m];
return answer;
}
let arr = [1, 2, 5];
console.log(solution(11, arr));