結果
問題 |
No.978 Fibonacci Convolution Easy
|
ユーザー |
![]() |
提出日時 | 2020-05-24 16:34:40 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 440 bytes |
コンパイル時間 | 94 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 166,212 KB |
最終ジャッジ日時 | 2024-10-11 20:56:44 |
合計ジャッジ時間 | 5,544 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 3 TLE * 1 -- * 17 |
ソースコード
import sys input=lambda: sys.stdin.readline().rstrip() n,p=map(int,input().split()) mod=10**9+7 if n==1: print(0) elif n==2: print(1) else: A=[0,1] B=[0,1] for _ in range(n-2): a=p*A[-1]+A[-2] if a>=mod: a%=mod b=pow(a,2,mod) A.append(a) B.append(b) a,b=0,0 for i in range(n): a+=A[i] if a>=mod: a%=mod b+=B[i] if b>=mod: b%=mod print(((a**2+b)*pow(2,mod-2,mod))%mod)