[BOJ] 2635. 수 이어가기 (🥈, 완전탐색)

lemythe423·2023년 12월 15일
0

BOJ 문제풀이

목록 보기
88/133
post-thumbnail

🔗

풀이

0을 포함하는 N보다 작은 모든 양의 정수를 두 번째 수로 설정하고 나올 수 있는 모든 배열을 구한 후 최대 길이를 갖는 값을 answer 로 출력한다.

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
import java.util.stream.Collectors;

public class Main {
    static int N;
    static List<Integer> answer = new ArrayList<Integer>();
    
    static List<Integer> makeNumber(int secondNumber, List<Integer> numbers) {
        numbers.add(N);
        numbers.add(secondNumber);

        int index = 0;
        int nextNumber = N - secondNumber;
        while (nextNumber >= 0) {
            numbers.add(nextNumber);
            index++;
            nextNumber = numbers.get(index) - numbers.get(index+1);
        }
        
        if (numbers.size() > answer.size()) return numbers;
        return answer;
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        N = sc.nextInt();
            
        for (int i = 0; i <= N; i++) {
            answer = makeNumber(i, new ArrayList<>());
        }
        
        System.out.println(answer.size());
        System.out.println(answer.stream().map(Object::toString).collect(Collectors.joining(" ")));
    }
}
profile
아무말이나하기

0개의 댓글