BOJ_1943_동전 분배 (Java)
[Gold II] 동전 분배 - 1943
성능 요약
메모리: 20772 KB, 시간: 4420 ms
분류
다이나믹 프로그래밍, 배낭 문제
제출 일자
2025년 5월 27일 22:30:13
문제 설명
윤화와 준희는 솔선수범하여 쓰레기를 줍는 착한 일을 하였다. 원장선생님께서는 윤화와 준희를 칭찬하시고 과자나 사 먹으라고 하시며 동전 몇 개를 윤화와 준희에게 건네 주었다.
그런데 돈을 받은 윤화와 준희는 좋아하기보다 고민에 빠지고 말았다. 원장선생님께 받은 이 돈을 어떻게 나누어 할지 고민에 빠진 것이다. 두 사람 모두 상대방이 자기보다 1원이라도 더 받는 것은 도저히 인정할 수 없어 한다. 따라서 돈을 똑같이 둘로 나누어 가져야 두 사람이 모두 만족할 수 있게 된다.
하지만 두 사람에게 돈을 똑같이 나누는 것이 불가능한 경우도 있다. 예를 들어 500원짜리 1개와 50원짜리 1개를 받았다면, 이 돈을 두 사람이 똑같이 나누어 가질 수는 없다. 물론 동전을 반으로 잘라서 나누어 가질 수도 있겠지만 그러면 돈으로서의 가치를 잃기 때문에 그렇게 할 수는 없다.
이제 우리가 할 일은 다음과 같다. 원장 선생님께서 N가지 종류의 동전을 각각 몇 개씩 주셨을 때, 그 돈을 반으로 나눌 수 있는지 없는지 판단하는 것이다.
입력
세 개의 입력이 주어진다. 각 입력의 첫째 줄에 동전의 종류 N(1 ≤ N ≤ 100)이 주어진다. 각 입력의 둘째 줄부터 N+1째 줄까지 각각의 동전의 금액과 개수가 빈 칸을 사이에 두고 주어진다. 단, 원장선생님께서 주신 금액의 총 합은 100,000원을 넘지 않는다. 동전의 금액과 개수는 자연수이고, 같은 금액을 가진 동전이 두 번 이상 주어지는 경우는 없다.
출력
첫째 줄부터 세 줄에 걸쳐, 각 입력에 대하여 반으로 나누는 것이 가능하면 1, 불가능하면 0을 출력한다.
문제 풀이
냅색 문제다. 1차원 배열로 풀었고 역순으로 진행했다.
코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/**
* Author: nowalex322, Kim HyeonJae
*/
import java.io.*;
import java.util.*;
public class Main {
static BufferedReader br;
static BufferedWriter bw;
static StringTokenizer st;
public static void main(String[] args) throws Exception {
new Main().solution();
}
public void solution() throws Exception {
br = new BufferedReader(new InputStreamReader(System.in));
// br = new BufferedReader(new InputStreamReader(new FileInputStream("src/main/java/BOJ_1943_동전분배/input.txt")));
bw = new BufferedWriter(new OutputStreamWriter(System.out));
for(int t=0; t<3; t++){
int N = Integer.parseInt(br.readLine());
int[] dp = new int[100001];
dp[0] = 1;
int total = 0;
for(int i=0; i<N; i++){
st = new StringTokenizer(br.readLine());
int price = Integer.parseInt(st.nextToken());
int number = Integer.parseInt(st.nextToken());
total += price * number;
for(int j = 0; j < number; j++) {
for(int k = 50000; k >= price; k--) {
if(dp[k - price] == 1) {
dp[k] = 1;
}
}
if(dp[total/2] == 1) break;
}
}
if(total % 2 == 1){
System.out.println(0);
}
else{
if(dp[total/2]==1) System.out.println(1);
else System.out.println(0);
}
}
bw.flush();
bw.close();
br.close();
}
}