結果
問題 | No.1448 和差算 |
ユーザー |
![]() |
提出日時 | 2021-03-31 14:44:51 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 44 ms / 2,000 ms |
コード長 | 508 bytes |
コンパイル時間 | 166 ms |
コンパイル使用メモリ | 82,216 KB |
実行使用メモリ | 52,480 KB |
最終ジャッジ日時 | 2024-12-14 21:50:34 |
合計ジャッジ時間 | 3,179 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 36 |
ソースコード
MOD = pow(10,9)+7 L = [[(1,0),(0,1)]] for i in range(7): aa = L[-1][0][0] - L[-1][1][0] ab = L[-1][0][1] - L[-1][1][1] ba = L[-1][0][0] + L[-1][1][0] bb = L[-1][0][1] + L[-1][1][1] L.append([(aa,ab),(ba,bb)]) #print(L) A,B,C,D = map(int,input().split()) N = int(input()) idx = (N+1)%8 #b_N+1 = a_N + b_N if L[idx][1][0] >= 0: p = B else: p = A if L[idx][1][1] >= 0: q = D else: q = C #print(p,q) ans = pow(16,(N+1)//8,MOD) * (p*L[idx][1][0] +q*L[idx][1][1]) print(ans%MOD)