백준 1551 수열의 변화
문제
크기가 N인 수열 A가 주어졌을 때, 세준이는 인접한 두 원소의 차이를 이용해서 크기가 N-1인 수열 B를 만들 수 있다.
예를 들어, A = {5,6,3,9,-1} 이었을 때, B = {6-5, 3-6, 9-3, -1-9} = {1,-3,6,-10}이 된다. 다른 말로 B[i] = A[i+1]-A[i]가 된다.
수열 A가 주어졌을 때, 세준이가 위의 방법을 K번 했을 때 나오는 수열을 구하는 프로그램을 작성하시오.
입력
첫째 줄에 수열의 크기 N과 K가 주어진다. N은 20보다 작거나 같은 자연수이고, K는 0보다 크거나 같고, N-1보다 작거나 같은 자연수이다. 둘째 줄에는 수열이 ‘,’로 구분되어 주어진다.
출력
첫째 줄에 K번 변형한 수열을 ‘,’로 구분하여 출력한다.
예제 입력 1
5 1
5,6,3,9,-1
예제 출력 1
1,-3,6,-10
풀이 과정
리스트를 만들고 얕은 복사로 옮겼는데 깊은 복사는 굳이 안해도 될 것 같았다.
리스트를 만들고 잘 유지하는 것이 중요하다.
코드
N, K = map(int, input().split())
data = list(map(int, input().split(',')))
result = data
for i in range(K):
tmp = [data[j + 1] - data[j] for j in range(N - i - 1)]
data = tmp
result = tmp
print(*result, sep=',')
Author And Source
이 문제에 관하여(백준 1551 수열의 변화), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@mynote/백준-1551-수열의-변화저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)