Algorithm/Greedy
(Python) - BOJ(2217번) : 로프
하눤석
2022. 1. 30. 21:06
728x90
https://www.acmicpc.net/problem/2217
- 해설 :
N(1 ≤ N ≤ 100,000)개의 로프가 있다. 이 로프를 이용하여 이런 저런 물체를 들어올릴 수 있다. 각각의 로프는 그 굵기나 길이가 다르기 때문에 들 수 있는 물체의 중량이 서로 다를 수도 있다.
하지만 여러 개의 로프를 병렬로 연결하면 각각의 로프에 걸리는 중량을 나눌 수 있다. k개의 로프를 사용하여 중량이 w인 물체를 들어올릴 때, 각각의 로프에는 모두 고르게 w/k 만큼의 중량이 걸리게 된다.
각 로프들에 대한 정보가 주어졌을 때, 이 로프들을 이용하여 들어올릴 수 있는 물체의 최대 중량을 구해내는 문제이다. 모든 로프를 사용해야 할 필요는 없으며, 임의로 몇 개의 로프를 골라서 사용해도 된다.
- 풀이 :
로프를 내림차순으로 정렬하여 로프를 한 개씩 추가로 선택하며 최대 중량을 갱신한다.
- 소스코드 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
num = int(input())
weight = []
for i in range(num):
a = int(input())
weight.append(a)
weight.sort(reverse=True)
max_weight = 0
added = 1
for i in range(len(weight)):
predict = weight[i]*added
added += 1
if predict >= max_weight:
max_weight = predict
print(max_weight)
|
cs |
320x100