728x90
문제
동전을 적절히 사용해서 가치의 합을 K로 만들려고 한다.
이때 필요한 동전 개수의 최솟값을 구하라.
입력
첫째 줄에 N과 K
N은 1이상 10이하
K는 1이상 일억이하
둘째 줄부터 N개의 줄에 동전의 가치 A가 오름차순으로 주어진다.
출력
K원을 만드는데 필요한 동전 개수의 최솟값 출력
직관적으로 화폐가치가 높은 것으로 채워야 동전의 개수가 최소가 된다.
따라서 입력받은 N개의 동전을 내림차순으로 정렬하여 하나씩 꺼내어 나눠본다.
나누었을 때 1이상이면 나눈 몫을 최종해에 더하고 (몫x화폐가치)만큼 K원에서 빼준다.
K가 0원이 되었을 때 반복문을 종료하도록 한다.
#include "pch.h"
#include <iostream>
#include<algorithm>
#include <vector>
using namespace std;
int main()
{
int N, K;
int coin[10];
cin >> N >> K;
for (int i = 0; i < N; i++) {
cin >> coin[i];
}
sort(coin, coin + N, greater<int>());
int answer = 0;
int idx = 0;
while (K != 0) {
if (K / coin[idx] > 0) {
int cnt = K / coin[idx];
answer += cnt;;
K -= (coin[idx] * cnt);
}
idx += 1;
}
cout << answer << endl;
return 0;
}
'알고리즘 풀이 > 백준' 카테고리의 다른 글
[백준 1946] 신입 사원 cpp (0) | 2021.02.05 |
---|---|
[백준 1931] 회의실 배정 (0) | 2021.02.05 |
[백준 11399] ATM cpp (0) | 2021.02.03 |
[백준 1018] 체스판 다시 칠하기 (0) | 2021.02.02 |
[백준 1182] 부분수열의 합 cpp (0) | 2021.02.02 |