https://www.acmicpc.net/problem/11047
문제


풀이
동전 배열이 오름차순으로 되어있기 때문에 역순으로 큰 수부터 탐색하는 것이 핵심이다
K가 동전 원소의 값보다 크면 K를 동전으로 나눌 수 있다는 뜻
K를 동전 원소로 나눈 값을 total에 더하고 K는 동전 원소로 나눈 나머지로 갱신한다
그러면 total은 동전 개수의 최솟값이 담겨있을 것이다
코드
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.*;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
StringBuilder sb = new StringBuilder();
st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int K = Integer.parseInt(st.nextToken());
int[] money = new int[N];
for (int i = 0; i < N; i++) {
money[i] = Integer.parseInt(br.readLine());
}
int total = 0;
// money 배열을 역순으로 탐색하면서 진행
for (int i = money.length - 1; i >= 0; i--) {
if (K >= money[i]) {
total += K / money[i];
K %= money[i];
}
if (K == 0) {
break;
}
}
System.out.println(total);
}
}
결과
