Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 토이프로젝트
- 동적프로그래밍
- 자료구조
- spring
- Router
- mysql
- java
- 백준
- 브루트포스
- sort
- BFS
- 탐욕법
- ELB
- 서버구축
- 정렬
- AWS
- 스터디
- 라우터
- EC2
- react
- nodejs
- 다익스트라 알고리즘
- 백준알고리즘
- EventListener
- 완전탐색
- Spring Boot
- url parsing
- 리액트
- 알고리즘
- Algorithm
Archives
- Today
- Total
공부하는 블로그
Baekjoon | Q.10844 - 쉬운 계단 수 본문
동적 프로그래밍을 이용해서 계단 수의 개수를 찾는 문제이다.
package p10844;
import java.util.Scanner;
public class Main {
static int[][] dp = new int[101][10];
static final int mod = 1000000000;
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
sc.close();
for (int i = 1; i < 10; i++) {
dp[1][i] = 1;
}
for (int i = 2; i <= n; i++) {
for (int j = 0; j < 10; j++) {
if(j == 0) {
dp[i][0] = dp[i-1][1] % mod;
}else if(j == 9) {
dp[i][9] = dp[i-1][8] % mod;
}else {
dp[i][j] = (dp[i-1][j-1] + dp[i-1][j+1]) % mod;
}
}
}
long sum = 0;
for (int i = 0; i < 10; i++) {
sum += dp[n][i];
}
System.out.println(sum % mod);
}
}
점화식을 찾기 어려워서 구글의 힘을 빌렸다...ㅎ
dp[i][j]는 길이가 i이고 마지막 자리의 수가 j인 계단 수의 개수를 의미한다. 길이가 i이고 마지막 자리의 수가 j인 계단 수는 길이가 i-1이고 마지막 자리의 수가 j-1 또는 j+1인 계단 수의 끝에 j만 붙여주면 된다.
예를 들자면 길이가 2인 계단 수는 10, 12, 21, 23, 32, 34, 43, 45, 54, 56... 가 있다. 길이가 3이고 마지막 자리의 수가 3인 계단 수는 길이가 2이고 끝 자리가 2 또는 4인 계단 수에 3만 붙여주면 된다. 따라서 123, 343, 323, 543 네 가지의 계단 수를 찾을 수 있다. 따라서 dp[i][j] = dp[i-1][j-1] + dp[i-1][j-1]의 점화식이 성립한다.
그러나 j가 0이나 9일 경우에는 이 점화식이 성립하지 않으므로 따로 조건분기를 통해 처리해 주었다. j가 0일 경우 j-1 = -1이 되어 마지막 자리 수가 -1이 되버리고, j가 9일 경우 j+1 = 10이 되어 자리 수가 증가해버린다.
따라서 최종 점화식은 다음과 같다.
j=0 일 때, dp[i][j] = dp[i-1][j+1]
0<j<9일 때, dp[i][j] = dp[i-1][j-1]+ dp[i-1][j+1]
j=9 일 때, dp[i][j] = dp[i-1][j-1]
'알고리즘 공부' 카테고리의 다른 글
Baekjoon | Q.11053 - 가장 긴 증가하는 부분 수열 (0) | 2020.06.11 |
---|---|
Baekjoon | Q.12865 - 평범한 배낭 (0) | 2020.06.10 |
Baekjoon | Q.9461 - 파도반 수열 (0) | 2020.06.09 |
Algorithm | Dynamic Programming & Greedy Algorithm (0) | 2020.06.08 |
Baekjoon | Q.10830 - 행렬 제곱 (0) | 2020.06.04 |
Comments