Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 카카오 블라인드 테스트
- 더 맵게
- 다리를 지나는 트럭
- programmers python
- level test 1
- 프로그래머스 기능개발
- 테스트케이스5
- 테스트케이스 7
- kakao blind recuritment
- programmers
- 프로그래머스
- 파이썬
- 프로그래머스 기능개발 파이썬3
- 멀쩡한 사각형 파이썬
- 서머 윈터코딩 파이썬
- 완전탐색
- 프로그래머스 가장 큰 수
- 파이썬3
- 프로그래머스 더 맵게 파이썬
- kakao blind recruitment
- Python
- 카카오블라인드
- programmers 체육복 파이썬 풀이
- python3
- level1
- 방금 그곡
- 프로그래머스 가장 큰 수 파이썬
- 124 나라의 숫자 파이썬
- programmers level test
- 프로그래멋
Archives
- Today
- Total
코린스토리
[Programmers] Level 2 Heap/ 라면공장 (파이썬) 본문
문제 설명
라면 공장에서는 하루에 밀가루를 1톤씩 사용합니다. 원래 밀가루를 공급받던 공장의 고장으로 앞으로 k일 이후에야 밀가루를 공급받을 수 있기 때문에 해외 공장에서 밀가루를 수입해야 합니다.
해외 공장에서는 향후 밀가루를 공급할 수 있는 날짜와 수량을 알려주었고, 라면 공장에서는 운송비를 줄이기 위해 최소한의 횟수로 밀가루를 공급받고 싶습니다.
현재 공장에 남아있는 밀가루 수량 stock, 밀가루 공급 일정(dates)과 해당 시점에 공급 가능한 밀가루 수량(supplies), 원래 공장으로부터 공급받을 수 있는 시점 k가 주어질 때, 밀가루가 떨어지지 않고 공장을 운영하기 위해서 최소한 몇 번 해외 공장으로부터 밀가루를 공급받아야 하는지를 return 하도록 solution 함수를 완성하세요.
dates[i]에는 i번째 공급 가능일이 들어있으며, supplies[i]에는 dates[i] 날짜에 공급 가능한 밀가루 수량이 들어 있습니다.
정답
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
import heapq
def solution(stock, dates, supplies, k):
answer = 0
idx=0
h=[]
while(stock<k):
for i in range(idx,len(dates)):
if dates[i]<=stock:
heapq.heappush(h,(-supplies[i],supplies[i]))
idx=i+1
else:
break
stock+=heapq.heappop(h)[1]
answer+=1
return answer
|
사유과정
여기서는 최소힙이 아니라 최대힙을 사용해야한다. 그래서 힙을 넣을 때 heapq.heappush(h,(-supplies[i],supplies[i]))와 같이 넣어준다. 꺼낼때도 heapq.heappop(h)[1]이렇게 꺼내준다!
'Programmers Test > Level 2' 카테고리의 다른 글
[Programmers] Level 2 탐욕법(greedy) 구명보트 (파이썬) (0) | 2020.01.18 |
---|---|
[Programmers] Level 2 해시/ 위장 (파이썬) (0) | 2020.01.16 |
[Programmers] Level 2 Heap 더 맵게 (파이썬) (0) | 2020.01.15 |
[Programmers] Level 2 가장 큰 수 (파이썬) (0) | 2020.01.15 |
[Programmers] Level 2 기능개발 파이썬 (0) | 2020.01.14 |