금의야행 2021. 8. 13. 13:26

https://www.acmicpc.net/problem/2164

 

2164번: 카드2

N장의 카드가 있다. 각각의 카드는 차례로 1부터 N까지의 번호가 붙어 있으며, 1번 카드가 제일 위에, N번 카드가 제일 아래인 상태로 순서대로 카드가 놓여 있다. 이제 다음과 같은 동작을 카드가

www.acmicpc.net

 

문제

 

내 풀이

from collections import deque
n = int(input())

Q = deque(range(1, n+1))

if len(Q) == 1:
    print(Q[0])

else:
    for i in range(len(Q)):
        Q.popleft()
        Q.append(Q.popleft())
        if len(Q) == 1:
            break
    print(Q[0])

해설

찬양하라 deque

단순히 문제에서 주어진 행동을 실행할 뿐인데도 시간복잡도가 충분하게 낮다!

 

 

 

정답 풀이

X

출처:

 

해석