본문 바로가기
알고리즘 문제풀이/프로그래머스

[프로그래머스] 더 맵게 - 파이썬(python)

by mine* 2024. 1. 20.
 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

문제

매운 것을 좋아하는 Leo는 모든 음식의 스코빌 지수를 K 이상으로 만들고 싶습니다. 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 Leo는 스코빌 지수가 가장 낮은 두 개의 음식을 아래와 같이 특별한 방법으로 섞어 새로운 음식을 만듭니다.

  • 섞은 음식의 스코빌 지수 = 가장 맵지 않은 음식의 스코빌 지수 + (두 번째로 맵지 않은 음식의 스코빌 지수 * 2)

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

제한 사항

  • scoville의 길이는 2 이상 1,000,000 이하입니다.
  • K는 0 이상 1,000,000,000 이하입니다.
  • scoville의 원소는 각각 0 이상 1,000,000 이하입니다.
  • 모든 음식의 스코빌 지수를 K 이상으로 만들 수 없는 경우에는 -1을 return 합니다.

풀이 설계

  • 입력받은 scoville을 heap으로 정렬한다.
  • While문으로 가장 작은 수 2개를 뽑아 tm1 + tm2*2 를하고 다시 scoville에 넣는다.
  • 처음으로 가져오는 tm1이 K보다 크다면 break한다.

1차 시도 (실패)

  • 예외처리를 생각하지 않아서 일부 테케에 실패했다...
import heapq

def solution(scoville, K):
    answer = 0
    heapq.heapify(scoville)
    while 1:
        tm1 = heapq.heappop(scoville)
        tm2 = heapq.heappop(scoville)
        if tm1 > K: break
        heapq.heappush(scoville, tm1+tm2*2)
        answer += 1

    return answer

2차 시도 (성공)

  • scoville의 길이가 1개일때 break를 안해줘서 무한루프 도는 바람에 런타임에러가 발생한 것같다.
  • tm1이 K와 같을때도 break를 하도록 바꿨다.
  • 아까 모든 음식을 섞어도 K가 되지 않는 경우를 처리해주지 않았어서 코드를 추가했다.
import heapq

def solution(scoville, K):
    answer = 0
    heapq.heapify(scoville)
    while len(scoville) > 1:
        tm1 = heapq.heappop(scoville)
        if tm1 >= K: break
        tm2 = heapq.heappop(scoville)
        heapq.heappush(scoville, tm1+tm2*2)
        answer += 1
    if scoville[0] < K:
        return -1
    return answer
왼쪽부터 1차시도, 2차시도

후기

  • heapify를 처음써봤는데 for문으로 하나씩 넣는것보다 편하다.
  • K가 불가능한 부분을 처음에 설계할 때부터 했어야 했는데 놓쳐서 다음엔 문제를 더 자세히 읽어야겠다.

댓글