Algorithm/Greedy
(Python) - BOJ(1817번) : 짐 챙기는 숌
하눤석
2022. 1. 28. 11:12
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