https://www.acmicpc.net/problem/2294
2294번: 동전 2
첫째 줄에 n, k가 주어진다. (1 ≤ n ≤ 100, 1 ≤ k ≤ 10,000) 다음 n개의 줄에는 각각의 동전의 가치가 주어진다. 동전의 가치는 100,000보다 작거나 같은 자연수이다. 가치가 같은 동전이 여러 번 주
www.acmicpc.net

소스코드
import java.util.Scanner;
public class Sanizzang {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int k = sc.nextInt();
int[] count = new int[k + 1];
for (int i = 0; i < k + 1; i++) {
count[i] = 100001;
}
count[0] = 0;
int[] coin = new int[n];
for (int i = 0; i < n; i++) {
coin[i] = sc.nextInt();
}
for (int i = 0; i < n; i++) {
for (int j = coin[i]; j <= k; j++) {
count[j] = Math.min(count[j], count[j - coin[i]] + 1);
}
}
System.out.println(count[k] == 100001 ? -1 : count[k]);
sc.close();
}
}
소스설명
1. 사용한 동전의 최소 개수를 저장하기위한 count 배열 생성
2. 동전의 최소가치인 100,000보다 1 높은 100,001를 count배열에 대입(사용한 동전의 개수가 최악일 경우 100,000개이기 때문)
3. coin배열에 있는 각각의 동전의 가치값들을 시행하기 위해 n번의 loop를 돌리고
4. 그 안에는 동전의 가치값부터 k까지의 최소 동전의 최소 사용 갯수만큼 카운트해준다.
5. 만약 최종적으로 count[k]의 값에 100001값이 들어있다면 입력된 동전의 가치로는 k원이 되지 못하므로 -1을 출력하고 그렇지 않으면 count[k]의 값을 출력하도록한다.
'Algorithm(Java) > BAEKJOON' 카테고리의 다른 글
| [JAVA] 백준 알고리즘 1449번 문제 풀이 (수리공 환승) (0) | 2021.09.25 |
|---|---|
| [JAVA] 백준 알고리즘 4796번 문제 풀이 (캠핑) (0) | 2021.09.25 |
| [JAVA] 백준 알고리즘 1463번 문제 풀이 (1로 만들기) (0) | 2021.09.24 |
| [JAVA] 백준 알고리즘 2231번 문제 풀이 (분해합) (0) | 2021.09.24 |
| [JAVA] 백준 알고리즘 2309번 문제풀이 (일곱 난쟁이) (0) | 2021.09.23 |