ror_coding

[Programmers] 더 맵게 - 42626 본문

Algorithm/Python

[Programmers] 더 맵게 - 42626

ro_rdil_31 2024. 12. 8. 16:07
728x90

첫 Heap 문제 ! 우선순위큐 ! 너무 유용하고 빠르고 편하고 좋다 ^^..

 

Question

 

Leo는 모든 음식의 스코빌 지수가 K 이상이 될 때까지 반복하여 섞습니다.
Leo가 가진 음식의 스코빌 지수를 담은 배열 scoville과 원하는 스코빌 지수 K가 주어질 때, 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 섞어야 하는 최소 횟수를 return 하도록 solution 함수를 작성해주세요.

  • 모든 음식의 스코빌 지수를 K 이상으로 만들 수 없는 경우에는 -1을 return 합니다.

 

Point

 

  • heapq를 이용하여 작은 값 두 개 m1, m2 뽑고 가장 작은 m1이 K보다 크다면 return.
  • 마지막에 모든 음식이 K 이상인지 확인하고 아니라면 -1 return.

 

Code

 

import heapq
def solution(scov, K):
    cnt = 0
    heapq.heapify(scov)
    while len(scov) > 1:
        m1 = heapq.heappop(scov)
        m2 = heapq.heappop(scov)
        if (m1 >= K) : return cnt
        new = m1 + m2*2
        heapq.heappush(scov, new)
        cnt += 1
        
    return cnt if scov[0] >= K else -1

 

now me

On my github

 

728x90