📝 문제
💡 크기가 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보다 작거나 같은 정수이다.
둘째 줄에는 수열이 ‘,’로 구분되어 주어진다.
수열을 이루고 있는 수는 절댓값이 100보다 작거나 같은 정수이다.
⚙️ 출력 : 첫째 줄에 K번 변형한 수열을 ‘,’로 구분하여 출력한다.
1551번: 수열의 변화
첫째 줄에 수열의 크기 N과 K가 주어진다. N은 20보다 작거나 같은 자연수이고, K는 0보다 크거나 같고, N-1보다 작거나 같은 정수이다. 둘째 줄에는 수열이 ‘,’로 구분되어 주어진다. 수열을 이루
www.acmicpc.net
✅ 풀이
n, k = map(int, input().split())
li = list(map(int, input().split(',')))
for i in range(k):
temp = []
for i in range(1, len(li), 1):
temp.append(li[i]-li[i-1])
li = temp
for i in range(len(li)):
if i == len(li)-1:
print(li[i])
else:
print(li[i],end=',')
💡 매 반복마다 임시 리스트를 초기화하여 각 원소들의 차를 삽입했고,
만들어진 임시 리스트로 원본 리스트를 갱신하는 방법을 이용했다.
결과를 ','로 구분하여 출력하도록 추가적으로 신경을 써주었다.