프로그래머스_더 맵게_python
2021. 7. 29. 23:23ㆍ코딩테스트
반응형
https://programmers.co.kr/learn/courses/30/lessons/42626
코딩테스트 연습 - 더 맵게
매운 것을 좋아하는 Leo는 모든 음식의 스코빌 지수를 K 이상으로 만들고 싶습니다. 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 Leo는 스코빌 지수가 가장 낮은 두 개의 음식을 아래와 같
programmers.co.kr
섞은 음식의 스코빌 지수 = 가장 맵지 않은 음식의 스코빌 지수 + (두 번째로 맵지 않은 음식의 스코빌 지수 * 2)
Leo가 가진 음식의 스코빌 지수를 담은 배열 scoville과 원하는 스코빌 지수 K가 주어질 때, 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 섞어야 하는 최소 횟수를 return
모든 음식의 스코빌 지수를 K 이상으로 만들 수 없는 경우에는 -1을 return 합니다.
import heapq
def solution(scoville, K):
answer = 0
h = []
for s in scoville:
heapq.heappush(h, s)
while h[0]< K:
if len(h)==1 :
return -1
heapq.heappush(h, heapq.heappop(h)+(heapq.heappop(h)*2))
answer += 1
return answer
[내코드]
heapq는 자동으로 오름차정렬됨. 그냥 pop으로 빼기만 하면 최소값이 빠짐.
import heapq as hq
def solution(scoville, K):
hq.heapify(scoville)
answer = 0
while True:
first = hq.heappop(scoville)
if first >= K:
break
if len(scoville) == 0:
return -1
second = hq.heappop(scoville)
hq.heappush(scoville, first + second*2)
answer += 1
return answer
[다른 사람 코드]
전반적으로 비슷함.
heapq.heapify(x) : 리스트 x를 즉각적으로 heap으로 변환함
반응형
'코딩테스트' 카테고리의 다른 글
프로그래머스_이중우선순위큐_python (0) | 2021.08.04 |
---|---|
프로그래머스_디스크 컨트롤러_python (0) | 2021.08.01 |
프로그래머스_다리를 지나는 트럭_python (0) | 2021.07.29 |
프로그래머스_주식가격_python (0) | 2021.07.27 |
프로그래머스_프린터_python (0) | 2021.07.25 |