들어가며
이 문제는 점화식을 구하면 풀리는 dp 문제입니다.
코드
package solved.ac.class3;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class 백준9095_123더하기 {
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
int t = Integer.parseInt(reader.readLine());
int[] dp = new int[13];
dp[1] = 1;
dp[2] = 2;
dp[3] = 4;
for (int i = 4; i <= 12; i++) {
dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3];
}
StringBuilder result = new StringBuilder();
for (int i = 0; i < t; i++) {
int n = Integer.parseInt(reader.readLine());
result.append(dp[n]).append("\n");
}
System.out.println(result);
}
}
풀이법
n일 때, 하나씩 결과값을 나열한 모습입니다.
1 - 1
2 - 2
3 - 4
4 - 7
5 - 13
6 - 24
7 - 44
잘 보시면 n-1, n-2, n-3 을 다 더하면 n이 되는 것을 확인하실 수 있습니다.
따라서 점화식을 도출할 수 있습니다.
'알고리즘 문제 풀이 > 백준' 카테고리의 다른 글
[백준]2805 - 나무 자르기 문제 풀이(Java,자바) (1) | 2025.01.26 |
---|---|
[백준]11047 - 동전 0 문제 풀이(Java,자바) (1) | 2025.01.26 |
[백준]2606 - 바이러스 문제 풀이(Java,자바) (0) | 2025.01.13 |
[백준]1463 - 1로 만들기 문제 풀이(Java,자바) (2) | 2025.01.07 |
[백준]1620 - 나는야 포켓몬 마스터 이다솜 문제 풀이(Java,자바) (0) | 2025.01.07 |