[백준]#1551 수열의 변화

SeungBird·2020년 8월 26일
0

⌨알고리즘(백준)

목록 보기
5/401
post-custom-banner

문제

크기가 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

풀이

import java.util.*;

public class Main {


    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = sc.nextInt();
        int K = sc.nextInt();
        sc.nextLine();
        String str = sc.nextLine();
        String[] arr = str.split(",");
        ArrayList<String> list = new ArrayList<>();

        for(int i=0; i<arr.length; i++) {
            list.add(arr[i]);
        }

        for(int i=0; i<K; i++) {
            ArrayList<String> result = solution(list);
            list = result;
        }
        for(int i=0; i<list.size(); i++) {
            if(i==list.size()-1)
                System.out.println(list.get(i));
            else
                System.out.print(list.get(i)+",");
        }
    }
    public static ArrayList<String> solution(ArrayList<String> list) {
        ArrayList<String> result = new ArrayList<>();
        for(int i=0; i<list.size()-1; i++) {
            result.add(Integer.toString(Integer.parseInt(list.get(i+1))-Integer.parseInt(list.get(i))));
        }
        return result;
    }
}
profile
👶🏻Jr. Programmer
post-custom-banner

0개의 댓글