반응형
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
'BaekJoon > Silver' 카테고리의 다른 글
[BOJ/JAVA] 백준 28278 : 스택 2 (자바) (0) | 2023.08.09 |
---|---|
[BOJ/JAVA] 백준 11727 : 2xn 타일링 2 (자바) (0) | 2023.08.07 |
[BOJ/JAVA] 백준 11725 : 2xn 타일링 (자바) (0) | 2023.08.05 |
[BOJ/JAVA] 백준 2579 : 계단 오르기 (자바) (0) | 2023.08.01 |
[BOJ/JAVA] 백준 1912 : 연속합 (자바) (0) | 2023.08.01 |
댓글