<문제 해석>
예제를 보면 N에 1을 넣었을 때 9가 출력된다. N은 1자리일 경우 올 수 있는 계단 수 즉 1부터 9까지(0으로 시작하는 수는 없다고함) 총 9가지이다.
그렇다면 2를 넣었을 경우를 생각해 보자.
[N=1]
각 자릿수별 1가지
[N=2]
앞자리가 1일 경우 10, 12
앞자리가 2일 경우 21, 23
앞자리가 3일 경우 32, 34 ...
앞자리가 8일 경우 87, 89
앞자리가 9일 경우 98
앞자리가 9일 경우를 제외하고 2가지
[N=3]
101, 121, 123
212, 210, 232, 234
321, 323, 343, 345 ...
878, 876, 898
987, 989
앞자리 1,8 -> 3가지
9 -> 2가지
나머지 ->4가지
[N=4]
1, 8 -> 6가지
9 -> 3가지
나머지 -> 7가지
4까지 계산하게 되면 일정한 규칙을 찾을 수 있다.
앞자리가 2~7일 경우 -> 전 단계의 1,8일 경우의 갯수 + 2~7일 경우의 갯수
앞자리가 1, 8 일 경우 -> 전 단계의 9일 경우의 갯수 + 2~7일 경우의 갯수
앞자리가 9일 경우 -> 전 단계의 1,8일 경우의 갯수
규칙을 찾았으니 이제 점화식 구할 일만 남았다.
점화식은 N값 별로 1부터 9까지의 자릿수의 케이스를 저장하기 위해 이중배열로 구성해야 한다.
따라서 아래 코드와 같이 구성하여 보았다.
주의할 점은 결과 값들에 대해 1000000000을 나눠주는 조건과 dp배열의 data type을 long타입으로 줘야 하는 것이다.
<소스코드>
import java.util.Scanner; public class Beak10844 { public static void main(String[] args) { //LONG TYPE 주의 할것!!! Scanner sc = new Scanner(System.in); int n = sc.nextInt(); long dp[][] = new long[n+1][10]; for(int i=0;i<=9;i++) { dp[1][i] = 1; } for(int i=2; i<=n; i++) { for(int j=0;j<10;j++) { if(j==0) dp[i][j] = dp[i-1][1]%1000000000; else if(j==9) dp[i][j] = dp[i-1][8]%1000000000; else dp[i][j] = (dp[i-1][j-1] + dp[i-1][j+1])%1000000000; } } long result=0; for(int i=1;i<10;i++) { result += dp[n][i]; } System.out.println(result%1000000000); } }
'algorism' 카테고리의 다른 글
9095 1,2,3 더하기 (0) | 2019.02.11 |
---|---|
11727 2xn 타일링 2 (0) | 2019.02.11 |
11726 2xn 타일링 (0) | 2019.02.11 |
1463 1로 만들기 (0) | 2019.02.11 |
11053 가장 긴 증가하는 부분 수열 java (0) | 2019.02.10 |