티스토리 뷰
728x90
https://www.acmicpc.net/problem/1817
- 해설 :
쌓여있는 책을 박스에 차곡차곡 넣어서 택배로 미리 보내려고 한다. 책은 탑처럼 차곡차곡 쌓여있기 때문에, 차례대로 박스에 넣을 수밖에 없다.
각각의 책은 무게가 있다. 그리고 박스는 최대 넣을수 있는 무게가 있다.
이 때, 필요한 박스의 최소개수를 구하면 된다.
- 풀이 :
박스에 담을 수 있는 무게보다 작은동안 쌓여있는 책을 하나씩 넣는다
순서가 있으므로 정렬은 할 수 없다.
- 소스코드 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import sys
input = sys.stdin.readline
if __name__ == "__main__":
N,M = map(int,input().split())
weight = list(map(int,input().split()))
curr = 0
ans = 1
if N == 0:
print(0)
exit()
for i in weight:
if i + curr > M:
curr = i
ans += 1
else:
curr += i
print(ans)
|
cs |
320x100
'Algorithm > Greedy' 카테고리의 다른 글
(Python) - BOJ(1946번) : 신입 사원 (0) | 2022.01.29 |
---|---|
(Python) - BOJ(1931번) : 회의실 배정 (0) | 2022.01.28 |
(Python) - BOJ(1783번) : 병든 나이트 (0) | 2022.01.28 |
(Python) - BOJ(1758번) : 알바생 강호 (0) | 2022.01.28 |
(Python) - BOJ(1744번) : 수 묶기 (0) | 2022.01.27 |
댓글
© 2022 WonSeok, All rights reserved