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
- 변수명
- 프로그래머스
- deque
- ZIP
- 부등호
- 임시 변수
- 함수
- 함수화
- 2020 채용
- min heap
- enumerate
- 힙
- 탈출 조건
- boolean
- permutations
- 그리디
- 중첩문
- 가이드
- 커리어
- 매직 넘버
- 가독성
- John Sonmez
- 중간 변수
- 코딩테스트
- 중첩
- 파이썬
- 대소 비교
- 조합
- 스택/큐
- max-heap
Archives
- Today
- Total
Better Code, Better Life
이중우선순위큐 - 프로그래머스 - 파이썬 풀이 본문
문제 풀이
빈 큐를 만듭니다.
그리고 동작들을 차례차례 수행합니다.
이 때 max를 구하는 경우 linear하게 구하고 min을 구하는 경우 heap 구조(log n)를 이용합니다.
이 문제는 min 구할 때 heap 구조 없이 해도 풀리네요...
클린 코드 작성법
- 매직 넘버의 경우, 적절한 상수명을 붙여 관리합니다.
- MAX_KEY
- MIN_KEY
- operations 같은 경우, 여러 동작으로 나누어집니다. 이를 각각 관리해줍니다.
- process
- 리스트가 비어있는지 확인할 때 함수를 통해 가독성을 높여줍니다.
- is_empty
해답 코드
import heapq
MAX_KEY = 1
MIN_KEY = -1
def solution(operations):
number_list = []
for operation in operations:
process(operation, number_list)
if is_empty(number_list):
number_list.append(0)
max_num = max(number_list)
min_num = min(number_list)
return [max_num, min_num]
def is_empty(list1):
empty = False
if not list1:
empty = True
return empty
def process(operation, number_list):
operation_dict = {"I": insert,
"D": delete}
command, number_str = operation.split()
number = int(number_str)
operation_dict[command](number, number_list)
def insert(number, number_list):
heapq.heappush(number_list, number)
def delete(number, number_list):
if number == MAX_KEY and number_list:
number_list.remove(max(number_list))
if number == MIN_KEY and number_list:
heapq.heappop(number_list)
도움이 됐다면 공감버튼을 눌러주세요! 질문이 있다면 댓글 달아주세요!
코딩테스트 연습 - 이중우선순위큐 | 프로그래머스
programmers.co.kr
'Coding Test > Programmers' 카테고리의 다른 글
소수 찾기 - 프로그래머스 - 파이썬 풀이 (2) | 2019.08.19 |
---|---|
모의고사 - 프로그래머스 - 파이썬 풀이 (0) | 2019.08.17 |
디스크 컨트롤러 - 프로그래머스 - 파이썬 풀이 (0) | 2019.08.13 |
라면공장 - 프로그래머스 - 파이썬 풀이 (0) | 2019.08.07 |
더 맵게 - 프로그래머스 - 파이썬 풀이 (0) | 2019.08.05 |
Comments