study/알고리즘

[python] programmers - 줄 서는 방법

It's Hyeeun Time 2022. 8. 9. 00:06

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

 

프로그래머스

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

programmers.co.kr

 

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
32
33
34
35
36
37
38
39
40
41
42
def solution(n, k):
    answer = []
    
    # n_lst => 1~n번째 사람들을 담은 배열
    n_lst = [i+1 for i in range(n)]
    # methods => idx번째까지 만들 수 있는 경의 수
    methods = [0]*(n)
    
    # method => 0번째일 때는 1, 1번째 일때는 1*2, 2번째 일때는 1*2*3 ...
    for i in range(n):
        if i == 0:
            methods[i] = 1
        else:
            methods[i] = methods[i-1]*(i+1)
    
     # 뒤집기
    methods = methods[::-1]
    
    # [a, b, c, d] => a는 k//(b에서 만들 수 있는 경의 수(tmp)) => b는 k-tmp//(c에서 만들 수 있는 경의 수(tmp))...
    i = 0
    while i < n:
        
        if k == 1:
            for j in range(len(n_lst)):
                answer.append(n_lst[j])
            break
            
        if len(n_lst) == 1:
            answer.append(n_lst[0])
            break
        
        # n=3, k=6처럼 k%i번째 경우의 수 == 0일 떄는 cnt -= 1을 해준다
        if k%methods[i+1== 0:
            cnt = k//methods[i+1]-1
        else:
            cnt = k//methods[i+1]
        answer.append(n_lst[cnt])
        n_lst.pop(cnt)
        k -= methods[i+1]*cnt
        i += 1
        
    return answer
cs