Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 2단계
- AWS
- 실전알고리즘
- 3단계
- 이것이 코딩테스트다 with 파이썬
- test-helper
- 1단계
- 그리디
- docker
- Object detection
- 코드수행
- 프로그래머스
- cs
- SWEA
- pytorch
- 모두를 위한 딥러닝 강좌 시즌1
- 딥러닝
- 자료구조 및 실습
- C++
- Python
- STL
- 전산기초
- 백준
- 머신러닝
- MySQL
- ssd
- 구현
- 파이썬
- ubuntu
- CS231n
Archives
- Today
- Total
곰퓨타의 SW 이야기
[프로그래머스 level3 이중우선순위큐] heapq 활용하기 본문
해결해야하는 문제는 다음과 같았다.
https://programmers.co.kr/learn/courses/30/lessons/42628
코딩테스트 연습 - 이중우선순위큐
programmers.co.kr
파이썬에서는 heapq를 활용하여 heap으로 배열을 만들어 간단하게 구할 수 있도록 하기 때문에 이를 활용하고자 하였다.
(나중에 직접 tree 클래스를 생성하여 만들어본다던가,, 그런 과정도 해봐야 될 것 같다..ㅎㅎ)
우선 I인 경우 들어오는 수를 저장하기 위한 heap을 생성하였다. 이는 heap자료구조 형태로 저장될 수 있도록 하였다.
I가 들어와서 값을 삽입해야하는 경우 heapq의 heappush를 활용하였고,
D가 들어온 경우, 1이면 최댓값을 제거해야하므로, 최댓값은 heap의 가장 마지막 원소일 것이기 때문에 pop으로 빼주었다.
그리고 -1이면 최솟값을 제거해야하므로 ,최솟값은 heapq에서 heappop을 활용하면, 최소힙에서 가장 작은 값을 빼주므로 heapq를 활용하였다.
그리고 마지막에 answer에는 heap이 비어있다면 0이 최댓값, 최솟값으로써 담길 것이고, 비어있지않다면 heap의 최댓값 최솟값을 담을 수 있도록 하였다.
이러한 아이디어를 바탕으로 작성한 코드는 다음과 같다.
import heapq
def solution(operations):
heap = []
heapq.heapify(heap)
for op in operations :
op_split = op.split()
if op_split[0]=='I' :
heapq.heappush(heap,int(op_split[1]))
else :
if op_split[1]=='1' and heap:
heap.pop()
elif op_split[1]=='-1' and heap:
heapq.heappop(heap)
answer = [max(heap) if heap else 0, min(heap) if heap else 0]
return answer
'TIL > 프로그래머스' 카테고리의 다른 글
[프로그래머스 level3 보석 쇼핑] 효율성테스트 뿌시기!(투포인터, 딕셔너리 활용하기) (0) | 2021.06.28 |
---|---|
[프로그래머스 level3 등굣길] dp 뿌시기! (0) | 2021.06.25 |
[프로그래머스 level3 다단계 칫솔 판매] 딕셔너리 활용하기 (0) | 2021.06.23 |
[프로그래머스 level3 셔틀버스] 시간을 '분' 단위로 처리하기 (0) | 2021.06.22 |
[프로그래머스 level3 디스크 컨트롤러] heapq 사용하기! (0) | 2021.06.18 |
Comments