Algorithm

[그리디] 백준-1715 카드 정렬하기 골드4 (Java)

차노도리 2023. 4. 2. 22:16

백준 1715번 : 카드 정렬하기

https://www.acmicpc.net/problem/1715

 

1715번: 카드 정렬하기

정렬된 두 묶음의 숫자 카드가 있다고 하자. 각 묶음의 카드의 수를 A, B라 하면 보통 두 묶음을 합쳐서 하나로 만드는 데에는 A+B 번의 비교를 해야 한다. 이를테면, 20장의 숫자 카드 묶음과 30장

www.acmicpc.net

 

풀이

  • 입력받은 값을 우선 순위 큐에 넣는다. (정렬을 하기 위해)
  • 우선 순위 큐에 2개 이상 존재할 때 두개를 꺼내서 합한 이후에 다시 우선순위 큐에 넣는 것을 반복한다. 

 

코드 (java)

import java.util.*;

public class Baejoon1715 {

    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();

        PriorityQueue<Long> pq = new PriorityQueue<Long>();

        for (int i = 0; i < n; i++) {
            pq.add(sc.nextLong());
        }

        long num = 0;
        while (pq.size() > 1) {
            long temp1 = pq.poll();
            long temp2 = pq.poll();

            num += temp1 + temp2;
            pq.add(temp1 + temp2);
        }

        System.out.println(num);

    }
}