結果

問題 No.980 Fibonacci Convolution Hard
ユーザー onakasuitacityonakasuitacity
提出日時 2020-10-27 19:38:31
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 490 bytes
コンパイル時間 1,106 ms
コンパイル使用メモリ 86,472 KB
実行使用メモリ 126,760 KB
最終ジャッジ日時 2023-09-29 03:22:25
合計ジャッジ時間 18,131 ms
ジャッジサーバーID
(参考情報)
judge14 / judge15
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
INF = 1 << 60
MOD = 10**9 + 7 # 998244353
sys.setrecursionlimit(2147483647)
input = lambda:sys.stdin.readline().rstrip()
def resolve():
    p = int(input())
    Q = [int(input()) - 2 for _ in range(int(input()))]
    m = max(Q)

    dp = [0] * (m + 1)
    dp[2] = 1
    dp[3] = 2 * p % MOD
    for i in range(4, m + 1):
        dp[i] = 2 * p * dp[i - 1] - (p**2 - 2) * dp[i - 2] + 2 * p * dp[i - 3] - dp[i - 4]
        dp[i] %= MOD

    for i in Q:
        print(dp[i])
resolve()
0