* Computer Science/Algorithm

baekjun 10844. 쉬운 계단 수

soicem 2018. 8. 6. 09:21

 계단을 오를 때 integer overflow를 방지하기 위하여 나머지를 더하는 문제.


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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include <iostream>
#include <cstring>
 
using namespace std;
 
int N;
int cache[101][10];
 
int letsBin(int level, int last) {
    if (level == N)
        return 1;
    int & ret = cache[level][last];
    if (ret != -1)
        return ret;
    ret = 0;
    
    if (last == 0) {
        ret += letsBin(level + 1, last + 1);
        ret %= 1000000000;
    }
        
    else if (last == 9) {
        ret += letsBin(level + 1, last - 1);
        ret %= 1000000000;
    }
        
    else {
        ret += letsBin(level + 1, last - 1+ letsBin(level + 1, last + 1);
        ret %= 1000000000;
    }
        
    
    return ret;
}
 
int main() {
    cin >> N;
    int result = 0;
    memset(cache, -1sizeof(cache));
    for (int i = 1; i < 10; i++) {
        result += letsBin(1, i);
        result %= 1000000000;
    }
        
    cout << result  << endl;
    //system("pause");
    return 0;
}
cs


'* Computer Science > Algorithm' 카테고리의 다른 글

baekjun 2156. 포도주 시식  (0) 2018.08.08
baekjun 2293. 동전1  (0) 2018.08.08
baekjun 1005. ACM Craft  (0) 2018.08.06
baekjun 1463. 1로 만들기  (0) 2018.08.02
baekjun 2579. 계단 오르기  (0) 2018.08.02