새소식

⌨️ Algorithms/프로그래머스

[Python] 프로그래머스 Lv2_프린터

2022. 8. 3. 21:58

  • -

https://school.programmers.co.kr/learn/courses/30/lessons/42587

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

"""
입출력 예시)

priorities = [2, 1, 3, 2], location = 2 -> 1
priorities = [1, 1, 9, 1, 1, 1], location = 0 -> 5
"""

from collections import deque

def solution(priorities, location):
    answer = 0
    d = deque([(v,i) for i,v in enumerate(priorities)]) # v: value, i: index

    while len(d):
        item = d.popleft() # popleft(): 맨 첫 번째 요소 제거 후 반환
        if d and max(d)[0] > item[0]:
            d.append(item)
        else:
            answer += 1
            if item[1] == location:
                break

    return answer

 

-> deque 이용 

  • deque
    • 큐의 앞, 뒤에서 삽입, 삭제가 가능한 큐 (double-ended queue)

 

https://velog.io/@nayoon-kim/%ED%8C%8C%EC%9D%B4%EC%8D%AC-deque

 

[파이썬] deque

파이썬을 이용해서 BFS를 풀면 주로 사용하게 되는 자료구조가 Deque다. 사용하기야 자주 사용하지만 생각보다 deque을 잘 모르고 사용한다는 생각이 들어서 정리를 하기로 했다.큐의 앞, 뒤에서 삽

velog.io

 

 

 


 

  • d = deque([(v,i) for i,v in enumerate(priorities)])
# priorities = [1, 1, 9, 1, 1, 1], location = 0

d = deque([(v,i) for i,v in enumerate(priorities)])

"""
d = deque([(1, 0), (1, 1), (9, 2), (1, 3), (1, 4), (1, 5)])
"""

 

  • item = d.popleft()
# priorities = [1, 1, 9, 1, 1, 1], location = 0

d = deque([(v,i) for i,v in enumerate(priorities)])

while len(d):
	item = d.popleft() # popleft(): 맨 첫 번째 요소 제거 후 반환
    print('item:', item)
    
"""
item: (1, 0)
item: (1, 1)
item: (9, 2)
item: (1, 3)
item: (1, 4)
item: (1, 5)
"""

 

Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다!