dowon 2023. 8. 1. 10:58

https://school.programmers.co.kr/learn/courses/30/lessons/42889?language=python3 

 

프로그래머스

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

programmers.co.kr

def solution(N, stages):
    stages.sort()
    last_people = len(stages)
    failure = {}
    
    for i in range(1, N+1):
        if last_people != 0:
            stage_people = stages.count(i)
            failure[i] = (stage_people / last_people)
            last_people -= stage_people
        else:
            failure[i] = 0
        
    result = sorted(failure.keys(), key = lambda key: failure[key], reverse = True)
    return result

1. 딕셔너리를 사용해야 한다

index를 기준으로 정렬해야 하기 때문에 dictinary 사용이 효율적이다

 

2. sorted에서는 딕셔너리의 keys()를 활용하고, key = lambda를 활용한다

 

3. if-else 사용한 것은 시간초과를 없애기 위해서다

만약 1스테이지에서 100명이 있고, 나머지 20만 스테이지까지 한 명도 없다면, 굳이 뒤의 스테이지를 확인할 필요가 없다

 

딕셔너리, sorted에서 key 사용, 시간초과 제거하는 법을 기억하자