Algorithm/Greedy

(Python/파이썬) - 백준(BOJ) 1092번 : 배

하눤석 2022. 5. 24. 10:15
728x90

https://www.acmicpc.net/problem/1092

 

1092번: 배

첫째 줄에 N이 주어진다. N은 50보다 작거나 같은 자연수이다. 둘째 줄에는 각 크레인의 무게 제한이 주어진다. 이 값은 1,000,000보다 작거나 같다. 셋째 줄에는 박스의 수 M이 주어진다. M은 10,000보

www.acmicpc.net


  • 문제 : 

지민이는 항구에서 일한다. 그리고 화물을 배에 실어야 한다. 모든 화물은 박스에 안에 넣어져 있다. 항구에는 크레인이 N대 있고, 1분에 박스를 하나씩 배에 실을 수 있다. 모든 크레인은 동시에 움직인다.

 

각 크레인은 무게 제한이 있다. 이 무게 제한보다 무거운 박스는 크레인으로 움직일 수 없다. 모든 박스를 배로 옮기는데 드는 시간의 최솟값을 구하는 프로그램을 작성하시오.

 

 

 


  • 풀이 :

그리디 알고리즘을 사용하여 해결할 수 있는 문제였습니다.

 

 

풀이입니다.

 

1. 모든 박스를 싣지 못하는 경우를 배제하기 위해 크레인의 무게 한도중 max값과 box의 무게 중 max값을 비교하여 가장 무거운 박스를 싣지 못한다면 -1을 출력한다.

 

2. 남아있는 박스가 있는 동안 남은 박스의 무게를 순회하여 크레인이 실을 수 있는 가장 무거운 박스를 싣게 한다.

 

 

 


  • 소스코드 : 
import sys
from collections import deque
input = sys.stdin.readline

N = int(input())
crain = sorted(list(map(int,input().split())), reverse=True)
box_n = int(input())
weight = deque(sorted(list(map(int,input().split())),reverse=True))
answer = 0
if weight[0] > crain[0]:
    print(-1)
    exit()
while weight:
    curr_crain = 0
    answer += 1
    for _ in range(box_n): # M
        w = weight.popleft()
        if curr_crain < N:  # 크레인을 다 사용하지 않은 경우
            if crain[curr_crain] >= w: # 크레인에 실을 수 있는 무게인 경우
                box_n -= 1
                curr_crain += 1
            else: # 크레인에 못 싣는 경우
                weight.append(w)
        else:
            weight.append(w)
    if answer >= 10000:
        break
print(answer)

320x100