본문 바로가기
알고리즘/소스코드

KOREATECH 1057: 걸기 쉬운 전화번호

by cjw.git 2020. 12. 11.

Link : judge.koreatech.ac.kr/problem.php?id=1057


Python

더보기
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
from sys import stdin
 
num = dict()
num[1= [24]
num[2= [135]
num[3= [26]
num[4= [157]
num[5= [2468]
num[6= [359]
num[7= [48]
num[8= [5790]
num[9= [68]
num[0= [8]
 
dp = [[0 for _ in range(101)] for _ in range(10)]
 
 
def solve(number, length):
    if length == 1:
        return 1
 
    if dp[number][length] != 0:
        return dp[number][length]
 
    result = 0
    for data in num[number]:
        result += solve(data, length - 1)
        result %= 1000000007
 
    dp[number][length] = result
    return result
 
 
test = int(stdin.readline().strip())
for i in range(test):
    n = int(stdin.readline().strip())
    result = 0
    for i in range(10):
        result += solve(i, n)
        result %= 1000000007
 
    print(result)
cs

FeedBack

  1.  

 

 

 

cjw.git@gmail.com

댓글