[JAVA] 백준 11286번 : 절댓값 힙

2024. 1. 2. 23:47·Algorithm/Beakjoon
목차
  1. 💡 우선순위 큐
반응형

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

 

11286번: 절댓값 힙

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

www.acmicpc.net


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.PriorityQueue;

public class Main {
    static int N, x;
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        N = Integer.parseInt(br.readLine());
        StringBuilder sb = new StringBuilder();
        //{원본 값, 절댓값}
        PriorityQueue<int[]> pq = new PriorityQueue<>(new Comparator<int[]>() {
            @Override
            public int compare(int[] o1, int[] o2) {
                if(o1[1] < o2[1]) return -1;
                else if(o1[1] > o2[1]) return 1;
                else {
                    if(o1[0] < o2[0]) return -1;
                    else if(o1[0] > o2[0]) return 1;
                }
                return 0;
            }
        });
        while (N-- > 0) {
            x = Integer.parseInt(br.readLine());
            if(x == 0){
                if(pq.isEmpty()) sb.append("0\n");
                else sb.append(pq.poll()[0]).append("\n");
                continue;
            }
            pq.add(new int[]{x, Math.abs(x)});
        }
        System.out.println(sb);
    }
}

💡 우선순위 큐

풀이

  • 절댓값 힙 연산 종류
    • x (x != 0) : 배열에 정수 x 를 넣는다
    • 0 : 절댓값이 가장 작은 값을 출력하고 그 값을 배열에서 제거해 출력 (비어있는 경우 0 출력)
      • 비교 순위 (1) 절댓값 기준 오름차순 (2) 원본 기준 오름차순
  • 주어지는 정수 변수형은 int
  • 원래 값, 절댓값 2가지로 저장 한 뒤, 순위는 절댓값으로 판별
반응형

'Algorithm > Beakjoon' 카테고리의 다른 글

[JAVA] 백준 14500번 : 테트로미노  (1) 2024.01.03
[JAVA] 백준 9375번 : 패션왕 신해빈  (1) 2024.01.03
[JAVA] 백준 7569번 : 토마토  (0) 2024.01.02
[JAVA] 백준 18870번 : 좌표 압축  (0) 2024.01.01
[JAVA] 백준 10026번 : 적록색약  (1) 2024.01.01
  1. 💡 우선순위 큐
'Algorithm/Beakjoon' 카테고리의 다른 글
  • [JAVA] 백준 14500번 : 테트로미노
  • [JAVA] 백준 9375번 : 패션왕 신해빈
  • [JAVA] 백준 7569번 : 토마토
  • [JAVA] 백준 18870번 : 좌표 압축
mopipi
mopipi
칠전팔기
mopipi
공부하는 사람
mopipi
전체
오늘
어제
  • 분류 전체보기 (162)
    • Java (4)
    • Spring (21)
      • Spring boot 입문 (16)
      • [dsc] Spring-Novice-Study (3)
    • SQL (5)
    • Algorithm (127)
      • Programmars (38)
      • Beakjoon (85)
    • Git (1)
    • 생각들 (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

hELLO· Designed By정상우.v4.5.2
mopipi
[JAVA] 백준 11286번 : 절댓값 힙

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.