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(" ")));
}
}