Home 백준 10844번 쉬운 계단 수
Post
Cancel

백준 10844번 쉬운 계단 수

정보

문제 바로가기 [클릭]

난이도: Silver1

관련 개념: #다이나믹 프로그래밍


조건

시간 제한메모리 제한
1 초256 MB

문제

45656이란 수를 보자.

이 수는 인접한 모든 자리의 차이가 1이다. 이런 수를 계단 수라고 한다.

N이 주어질 때, 길이가 N인 계단 수가 총 몇 개 있는지 구해보자. 0으로 시작하는 수는 계단수가 아니다.


입력

첫째 줄에 N이 주어진다. N은 1보다 크거나 같고, 100보다 작거나 같은 자연수이다.


출력

첫째 줄에 정답을 1,000,000,000으로 나눈 나머지를 출력한다.


예제 입출력 1

입력

1
1

출력

1
9

예제 입출력 2

입력

1
2

출력

1
17

코드(파이썬)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
n = int(input())
dp = [0] + [1]*9
remainder = 1000000000

for _ in range(n-1):
    tmp = dp.copy()
    
    dp[0] = tmp[1]
    for i in range(1, 9):
        dp[i] = (tmp[i-1] + tmp[i+1]) % remainder
    dp[9] = tmp[8]

print(sum(dp) % remainder)


특이사항

  • 간단한 DP 문제

참고문헌

-

This post is licensed under CC BY 4.0 by the author.

백준 2565번 전깃줄

백준 17298번 오큰수

Comments powered by Disqus.