알고리즘/BOJ
[백준] 2590 색종이
세진짱
2020. 2. 4. 10:59
그리디 문제다
큰 색종이부터 붙여보면 된다
근데 헷갈린다..
함수화를 잘하면 코드가 짧아지는거같은데..
나는 무식하게 짰다
진짜 다 붙여보자!
소스코드
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
#include <iostream>
using namespace std;
int arr[7],ans;
int solve(int size) {
int ret = 0;
if (size == 6) ret += arr[6];
if (size == 5) {
ret += arr[5];
arr[1] -= 11 * arr[5];
if (arr[1] < 0) arr[1] = 0;
}
if (size == 4) {
ret += arr[4];
arr[2] -= 5 * arr[4];
if (arr[2] < 0) arr[1] += 4 * arr[2];
if (arr[2] < 0) arr[2] = 0;
if (arr[1] < 0) arr[1] = 0;
}
if (size == 3) {
ret += (arr[3] / 4);
arr[3] %= 4;
if (arr[3]) {
ret += 1;
if (arr[3] == 3) {
if (arr[2]) {
arr[2] -= 1;
arr[1] -= 5;
}
else arr[1] -= 9;
}
else if (arr[3] == 2) {
if (arr[2]) {
arr[2] -= 3;
arr[1] -= 6;
}
else arr[1] -= 18;
}
else if (arr[3] == 1) {
if (arr[2]) {
arr[2] -= 5;
arr[1] -= 7;
}
else arr[1] -= 27;
}
if (arr[1] < 0) arr[1] = 0;
if (arr[2] < 0) arr[2] = 0;
}
}
if (size == 2) {
ret += (arr[2] / 9);
arr[2] %= 9;
if (arr[2]) {
ret += 1;
arr[1] -= (9 - arr[2]) * 4;
if (arr[1] < 0) arr[1] = 0;
}
}
if (size == 1) {
ret += (arr[1] / 36);
if (arr[1] % 36) ret += 1;
}
return ret;
}
int main() {
for (int i = 1; i <= 6; i++) scanf(" %d", &arr[i]);
for (int i = 6; i >= 1; i--) {
if (arr[i]) ans += solve(i);
}
printf("%d\n", ans);
}
|