[그리디 알고리즘17] 백준 15903 카드 합체 놀이 파이썬
본문 바로가기
Python/Python 코딩테스트

[그리디 알고리즘17] 백준 15903 카드 합체 놀이 파이썬

by 쏠수있어ㅤ 2021. 7. 25.
반응형

백준 15903 카드 합체 놀이 

 

📜 문제 

석환이는 아기다. 아기 석환이는 자연수가 쓰여져있는 카드를 갖고 다양한 놀이를 하며 노는 것을 좋아한다. 오늘 아기 석환이는 무슨 놀이를 하고 있을까? 바로 카드 합체 놀이이다!

아기 석환이는 자연수가 쓰여진 카드를 n장 갖고 있다. 처음에 i번 카드엔 ai가 쓰여있다. 카드 합체 놀이는 이 카드들을 합체하며 노는 놀이이다. 카드 합체는 다음과 같은 과정으로 이루어진다.

  1. x번 카드와 y번 카드를 골라 그 두 장에 쓰여진 수를 더한 값을 계산한다. (x ≠ y)
  2. 계산한 값을 x번 카드와 y번 카드 두 장 모두에 덮어 쓴다.

이 카드 합체를 총 m번 하면 놀이가 끝난다. m번의 합체를 모두 끝낸 뒤, n장의 카드에 쓰여있는 수를 모두 더한 값이 이 놀이의 점수가 된다. 이 점수를 가장 작게 만드는 것이 놀이의 목표이다.

아기 석환이는 수학을 좋아하긴 하지만, 아직 아기이기 때문에 점수를 얼마나 작게 만들 수 있는지를 알 수는 없었다(어른 석환이는 당연히 쉽게 알 수 있다). 그래서 문제 해결 능력이 뛰어난 여러분에게 도움을 요청했다. 만들 수 있는 가장 작은 점수를 계산하는 프로그램을 만들어보자.

 

🚩 입력 

첫 번째 줄에 카드의 개수를 나타내는 수 n(2 ≤ n ≤ 1,000)과 카드 합체를 몇 번 하는지를 나타내는 수 m(0 ≤ m ≤ 15×n)이 주어진다.

두 번째 줄에 맨 처음 카드의 상태를 나타내는 n개의 자연수 a1, a2, …, an이 공백으로 구분되어 주어진다. (1 ≤ ai ≤ 1,000,000)

 

🌞 출력

첫 번째 줄에 만들 수 있는 가장 작은 점수를 출력한다.

 

👰 문제 풀이 

먼저 시간 제한이 1초이고 카드 합체를 하는 수가 1<= a <= 1,000,000 으로 매우 크다. pop, push 를 기존 리스트보다 더 빠르게 할 수 있는 heapq를 import 해와서 pop을 사용하면 된다. pop은 기본적으로 heapq에서 가장 작은 수를 pop해주기 때문에 sort()를 굳이 할 필요가 없었다. 

 

가장 작은걸 pop 두 번 해주고 해당 더한 값을 각각 대입해주면 끝 ! 

 

 

🥕 정답 코드 

import sys
import heapq
input = sys.stdin.readline

n, m = map(int,input().split())
arr = list(map(int,input().split()))

# H =[]                     // heapq 로 for문으로 만들었는데 heapq.heapify 라는 매서드 존재 !! 
# for i in arr:
#     heapq.heappush(H,i)


heapq.heapify(arr)

for i in range(m):
    x = heapq.heappop(arr)
    y = heapq.heappop(arr)
    heapq.heappush(arr,x+y)
    heapq.heappush(arr,x+y)
print(sum(arr))

그냥 리스트에 바로 heapq.heappop 매서드 등을 사용하니까 우선순위 큐가 안되었다. 그래서 for문으로 heapq.heappush로 넣어줬는데 heapq.heapify() 라는 매서드를 나중에 알게되었슴,,, 

 

 

 

반응형

댓글