문제 설명
1. N 개의 정수를 가진 리스트 A와 정수 K가 입력으로 주어진다.
2. 문제의 목표는 A리스트를 K번 회전한 결과 리스트를 리턴하는 것.
3. 회전이란 리스트의 모든 요소가 하나씩 오른쪽으로 이동하는 것을 말한다(마지막 요소는 첫번째로 이동)
풀면서 주의할 점은 예외케이스를 놓치지 않는 것이다.
입력으로 빈 리스트가 주어지거나
리스트는 입력 됬는데 회전 횟수가 0으로 입력되는 경우를 처음에 생각못해서 헤맸다...
you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A, K):
# write your code in Python 3.6
if len(A) == 0: ## 빈 리스트가 입력으로 들어올 수 있다.
return []
if K == 0: ## 리스트만 입력되고 회전 수가 0으로 주어질 수 있다.
return A
while K > 0:
result = []
for i in range(len(A)):
if i == 0:
result.append(A[-1])
else:
result.append(A[i-1])
A = result
K -= 1
return result
pass
'개발자의 기본기 > 알고리즘 문제' 카테고리의 다른 글
<Codility> Lesson1. Binary Gap (python) (0) | 2021.02.27 |
---|---|
[공부] 파이썬 알고리즘 문제 풀이 tip (1) | 2021.02.27 |
<백준 알고리즘> 1158번 조세퍼스 문제 (0) | 2020.09.26 |
<백준 알고리즘> 11718번 그대로 출력하기 (0) | 2020.09.26 |
<백준 알고리즘> 1076번 저항 (0) | 2020.09.26 |