문제
해결
DP
모든 가치를 살펴봄
- 현재 가치의 코인 갯수와 (현재가치 - 각 코인)의 가치 코인 갯수를 비교
$O(n\cdot k)$
소스코드
#include <bits/stdc++.h>
#include <fstream>
using namespace std;
int n, k;
int cache[100010];
vector<int> coins;
int main(void) {
freopen("input.txt", "r", stdin);
ios_base::sync_with_stdio(false);
cin.tie(NULL); cout.tie(0);
cin >> n >> k;
for(int input = 0, i = 0; i < n; i++) {
cin >> input;
// do not push overlapped coin
if(cache[input] == 0) coins.push_back(input);
cache[input] = 1;
}
for(int i = 1; i <= k; i++)
for(int coin : coins) {
if(i - coin < 0 || cache[i - coin] == 0) continue;
if(cache[i] == 0) cache[i] = cache[i - coin] + 1;
else cache[i] = min(cache[i - coin] + 1, cache[i]);
}
cout << (cache[k] ? cache[k] : -1) << "\n";
return 0;
}
'Coding Test > 백준' 카테고리의 다른 글
12100번 / 2048 (Easy) (0) | 2021.06.13 |
---|---|
15686번 / 치킨 배달 (0) | 2021.04.23 |
14889번 / 스타트와 링크 (0) | 2021.04.19 |
14888번 / 연산자 끼워넣기 (0) | 2021.04.19 |
1890번 점프 (0) | 2021.04.18 |
Comment