알고리즘 문제풀이

백준 - 절대값 힙 11286(Python)

2023. 3. 24. 21:23
목차
  1. 문제설명
  2. 입력
  3. 출력
  4. 예제입력 / 예제출력
  5. 문제이해 및 코드설명
  6. 코드
반응형
[Silver I] 절댓값 힙 - 11286
https://www.acmicpc.net/problem/11286

 

문제설명

절댓값 힙은 다음과 같은 연산을 지원하는 자료구조이다.

  1. 배열에 정수 x (x ≠ 0)를 넣는다.
  2. 배열에서 절댓값이 가장 작은 값을 출력하고, 그 값을 배열에서 제거한다. 절댓값이 가장 작은 값이 여러개일 때는, 가장 작은 수를 출력하고, 그 값을 배열에서 제거한다.

프로그램은 처음에 비어있는 배열에서 시작하게 된다.

 

입력

첫째 줄에 연산의 개수 N(1≤N≤100,000)이 주어진다. 다음 N개의 줄에는 연산에 대한 정보를 나타내는 정수 x가 주어진다. 만약 x가 0이 아니라면 배열에 x라는 값을 넣는(추가하는) 연산이고, x가 0이라면 배열에서 절댓값이 가장 작은 값을 출력하고 그 값을 배열에서 제거하는 경우이다. 입력되는 정수는 -231보다 크고, 231보다 작다.

 

출력

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

 

 

예제입력 / 예제출력

 

문제이해 및 코드설명

우선순위 큐를 해결하기 위해 힙 자료구조를 사용하는 문제이다. 

이 문제의 포인트는 절대값을 어떻게 처리해주느냐이다. heappush로 heap자료구조에 입력을 해줄 때 튜플형식으로절대값과 원래값으로 입력을 해주고 출력할 때 나오는 결과물을 원래값을 출력한다면, 절대값의 크기대로 최소 힙을 적용한 값을 구할 수 있다. 

 

코드

import sys
import heapq

N = int(sys.stdin.readline())
heap = []

for _ in range(N):
    x = int(sys.stdin.readline())

    if x == 0:
        if len(heap)==0:
            print(0)
        else:
            print(heapq.heappop(heap)[1])
    # 절대값, 값 순으로 입력
    else:
        heapq.heappush(heap,(abs(x),x))

 

반응형

'알고리즘 문제풀이' 카테고리의 다른 글

백준 - N번째 큰 수 2075 (Python)  (0) 2023.03.24
백준 - 최소 힙 1927 (Python)  (0) 2023.03.24
백준 - 최대 힙 11279 (Python)  (0) 2023.03.24
백준 - 큐 2 18258 (Python)  (0) 2023.03.09
백준 - 카드2 2164 (Python)  (0) 2023.03.09
  1. 문제설명
  2. 입력
  3. 출력
  4. 예제입력 / 예제출력
  5. 문제이해 및 코드설명
  6. 코드
'알고리즘 문제풀이' 카테고리의 다른 글
  • 백준 - N번째 큰 수 2075 (Python)
  • 백준 - 최소 힙 1927 (Python)
  • 백준 - 최대 힙 11279 (Python)
  • 백준 - 큐 2 18258 (Python)
coryne
coryne
반응형
coryne
coryne의 정리노트
coryne
전체
오늘
어제
  • 분류 전체보기 (56)
    • python (2)
    • Web programing (1)
    • Linux (3)
    • Deep Learning (0)
    • 기타 (0)
    • 알고리즘 문제풀이 (49)
    • 빅데이터분석기사 (0)
    • 알고리즘 이론 (1)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 공공데이터일경험수련생
  • 수학
  • 우선순위 큐
  • 정렬
  • 그래프 이론
  • 큐
  • 문자열
  • 너비 우선 탐색
  • 소수 판정
  • 자료구조
  • 정수론
  • EduAtoZ
  • Python
  • 빅데이터분석기사
  • 구현
  • 출처 : eduatoz
  • 백준
  • 다이나믹 프로그래밍
  • 그래프 탐색
  • 자료 구조
  • 빅데이터분석기사 실기
  • 데이크스트라
  • 스택
  • 그리디 알고리즘
  • machine_learning
  • 깊이 우선 탐색
  • 브루트포스 알고리즘
  • 플로이드-워셜
  • 자료 구조(data_structures)
  • pandas

최근 댓글

최근 글

hELLO · Designed By 정상우.
coryne
백준 - 절대값 힙 11286(Python)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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