본문 바로가기
BaekJoon/Silver

[BOJ/JAVA] 백준 1927 : 최소 힙 (자바)

by HoonSikE 2023. 10. 18.
반응형
SMALL
문제 정보
  문제명   - 최소 힙
  난이도   - 실버 II
문제 번호 - 1927번

문제 링크

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

 

1927번: 최소 힙

첫째 줄에 연산의 개수 N(1 ≤ N ≤ 100,000)이 주어진다. 다음 N개의 줄에는 연산에 대한 정보를 나타내는 정수 x가 주어진다. 만약 x가 자연수라면 배열에 x라는 값을 넣는(추가하는) 연산이고, x가 0

www.acmicpc.net


문제
널리 잘 알려진 자료구조 중 최소 힙이 있다. 최소 힙을 이용하여 다음과 같은 연산을 지원하는 프로그램을 작성하시오.
 1. 배열에 자연수 x를 넣는다.
 2. 배열에서 가장 작은 값을 출력하고, 그 값을 배열에서 제거한다.
프로그램은 처음에 비어있는 배열에서 시작하게 된다.

입력
첫째 줄에 연산의 개수 N(1 ≤ N ≤ 100,000)이 주어진다. 다음 N개의 줄에는 연산에 대한 정보를 나타내는 정수 x가 주어진다. 만약 x가 자연수라면 배열에 x라는 값을 넣는(추가하는) 연산이고, x가 0이라면 배열에서 가장 작은 값을 출력하고 그 값을 배열에서 제거하는 경우이다. x는 2^31보다 작은 자연수 또는 0이고, 음의 정수는 입력으로 주어지지 않는다.

출력
입력에서 0이 주어진 횟수만큼 답을 출력한다. 만약 배열이 비어 있는 경우인데 가장 작은 값을 출력하라고 한 경우에는 0을 출력하면 된다.

예제 입력/출력
예제 입력 예제 출력
9
0
12345678
1
2
0
0
0
0
32
0
1
2
12345678
0

알고리즘 분류
● 자료 구조
 우선순위 큐

소스코드
import java.io.*;
import java.util.*;

/**
 * @author HanHoon
 * @category 자료 구조, 우선순위 큐
 * https://www.acmicpc.net/problem/1927
 */
public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder str = new StringBuilder();

        // N: 연산의 개수
        int N = Integer.parseInt(br.readLine());
        /**
         * 우선순위 큐: 들어간 순서에 상관없이 우선순위가 높은 데이터가 먼저 나오는 것을 의미
         * 힙을 가지고 구현할 수 있다.
         */
        PriorityQueue<Integer> queue = new PriorityQueue<>();

        for (int n = 0; n < N; n++){
            // 연산에 대한 정보 (자연수: 입력, 0: 가장 작은 값 출력 및 제거)
            int x = Integer.parseInt(br.readLine());

            if(x == 0){
                if(queue.isEmpty())
                    str.append(0).append("\n");
                else
                    str.append(queue.poll()).append("\n");
            }else{
                queue.add(x);
            }
        }
        System.out.print(str);
        br.close();
    }
}

 


BaekJoon List
 

BaekJoon List

BOJ Start!! ● [BOJ] 백준 회원가입, 시작하는 법 ● [BOJ] 등급(티어) 및 Solved.AC 적용 ● [BOJ/JAVA] 백준 소스코드 제출 시 유의사항(자바) Bronze ● Bronze V  - ● Bronze IV  - ● Bronze III  -..

han-hoon.tistory.com


  

기회는 준비된 자에게 찾아온다.

 


 

반응형
LIST

댓글