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 |