운동하는 개발자/알고리즘, 코딩테스트
programmers [level2] 프린터 /알고리즘 프로그래머스
우용현
2021. 3. 25. 23:07
728x90
문제 주소 : programmers.co.kr/learn/courses/30/lessons/42587
난이도 : Level2
문제
- 일반적인 프린터는 인쇄 요청이 들어온 순서대로 인쇄합니다. 그렇기 때문에 중요한 문서가 나중에 인쇄될 수 있습니다. 이런 문제를 보완하기 위해 중요도가 높은 문서를 먼저 인쇄하는 프린터를 개발했습니다. 이 새롭게 개발한 프린터는 아래와 같은 방식으로 인쇄 작업을 수행합니다.
풀이
- 큐를 구성해놓고 순서가 궁금한 값의 위치를 저장해놓는다
하나씩 빼서 우선순위 맥스 값과 비교하고 최댓값이면 출력 아니면 맨뒤로 추가
이동시킬 때마다 위치 값도 같이 한 칸씩 변환
출력시킬 값의 인덱스가 0번이면 종료
답안
def solution(priorities, location):
nNowPos = location
answer = 1
while True:
nTemp = priorities.pop(0)
if len(priorities) == 0:
break
if nTemp >= max(priorities):
if nNowPos == 0:
break
else:
nNowPos -= 1
if nNowPos < 0:
nNowPos = len(priorities)
answer += 1
else:
priorities.append(nTemp)
nNowPos -= 1
if nNowPos < 0:
nNowPos = len(priorities)-1
return answer
solution([2, 1, 3, 2],2)
# from collections import deque
# def solution(priorities, location):
# dpriorities = deque(priorities)
# nNowPos = location
# answer = 1
# while True:
# nTemp = dpriorities.popleft()
# if len(dpriorities) == 0:
# break
# if nTemp >= max(dpriorities):
# if nNowPos == 0:
# break
# else:
# nNowPos -= 1
# if nNowPos < 0:
# nNowPos = len(dpriorities)
# answer += 1
# else:
# dpriorities.append(nTemp)
# nNowPos -= 1
# if nNowPos < 0:
# nNowPos = len(dpriorities)-1
# return answer
느낀 점
더보기
큐로 만든 간단한 문제 파이썬은 리스트를 큐처럼 활용하면 pop 할 때 시간 복잡도가 N이라서 타임아웃이 걱정되었으나 한방에 통과하였다 추후 문제 푼사람들을 보니 deque라는걸 사용하면 pop할 때 시간복잡도가 1이라 해서 비교해보았는데
100개 이하의 데이터라 그런지 체감이 전혀 안되었다... 오히려 더 느린 부분이 존재하기도
어쨌건 하나 배워놨으니 나중에 써먹어봐야지
근데 코딩 테스트할 때 라이브러리들을 이렇게 import 해서 사용해도 되는 건가 싶기도 하고..
그리고 분명 level 2에서 너무 어려운 것도 있었는데 지금은 또 너무 쉬워서 3단계로 가야 하나 고민되네 두어 개만 더 풀어보고 정해야겠다
728x90