관리 메뉴

솜씨좋은장씨

[Programmers] 스택/큐 : 프린터 (Python) 본문

Programming/코딩 1일 1문제

[Programmers] 스택/큐 : 프린터 (Python)

솜씨좋은장씨 2020. 3. 1. 16:49
728x90
반응형

1일 1문제 24일차!

오늘의 문제는 프로그래머스 스택 큐 프린터입니다.

 

코딩테스트 연습 - 프린터 | 프로그래머스

일반적인 프린터는 인쇄 요청이 들어온 순서대로 인쇄합니다. 그렇기 때문에 중요한 문서가 나중에 인쇄될 수 있습니다. 이런 문제를 보완하기 위해 중요도가 높은 문서를 먼저 인쇄하는 프린터를 개발했습니다. 이 새롭게 개발한 프린터는 아래와 같은 방식으로 인쇄 작업을 수행합니다. 1. 인쇄 대기목록의 가장 앞에 있는 문서(J)를 대기목록에서 꺼냅니다. 2. 나머지 인쇄 대기목록에서 J보다 중요도가 높은 문서가 한 개라도 존재하면 J를 대기목록의 가장 마지막에

programmers.co.kr

첫번째 시도

def solution(priorities, location):
    answer = 0
    
    pri_dict = {}
    
    for i in range(len(priorities)):
        pri_dict.update({i+1:priorities[i]})
    pri_dict = sorted(pri_dict.items(), key=lambda x: -x[1])
    
    for i in range(len(pri_dict)):
        if pri_dict[i][0] == location + 1:
            answer = i + 1
            break
    return answer

두번째 시도

def solution(priorities, location):
    answer = 0
    
    stack = []
    
    pri = [(i, p) for i, p in enumerate(priorities)]
    
    for i in range(len(priorities)-1):
        max_pri = max(priorities[i+1:])
        
        temp = pri[0]
        pri = pri[1:]
        
        if priorities[i] < max_pri:
            pri.append(temp)
        else:
            stack.append(temp)
            
    for i in range(len(pri)):
        stack.append(pri[i])
            
    for i in range(len(stack)):
        if stack[i][0] == location:
            answer = i + 1
            break
            
            
            
    
    return answer

세번째 시도

def solution(priorities, location):
    answer = 0
    while priorities!=[]:
        max_pri=max(priorities)
        pop_num=priorities.pop(0)
        if max_pri==pop_num:
            answer+=1
            if location==0:
                break
            else:
                location -=1
        else:
            priorities.append(pop_num)
            if location==0:
                location=len(priorities)-1
            else:
                location-=1
    return answer

 

 

SOMJANG/CODINGTEST_PRACTICE

1일 1문제 since 2020.02.07. Contribute to SOMJANG/CODINGTEST_PRACTICE development by creating an account on GitHub.

github.com

 

Comments