結果
| 問題 | No.1448 和差算 | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2024-10-30 09:30:02 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 38 ms / 2,000 ms | 
| コード長 | 554 bytes | 
| コンパイル時間 | 3,361 ms | 
| コンパイル使用メモリ | 81,840 KB | 
| 実行使用メモリ | 53,416 KB | 
| 最終ジャッジ日時 | 2024-10-30 09:30:09 | 
| 合計ジャッジ時間 | 3,633 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 36 | 
ソースコード
A,B,C,D = map(int,input().split())
N = int(input())
MOD = 10**9+7
q = (N-1)//4
r = (N-1)%4
if r==0:
    if q%2==0:
        ans = (2*pow(4,q,MOD)*B)%MOD
    else:
        ans = (-2*pow(4,q,MOD)*A)%MOD
elif r==1:
    if q%2==0:
        ans = (2*pow(4,q,MOD)*(B-C))%MOD
    else:
        ans = (-2*pow(4,q,MOD)*(A-D))%MOD
elif r==2:
    if q%2==0:
        ans = (-pow(4,q+1,MOD)*C)%MOD
    else:
        ans = (pow(4,q+1,MOD)*D)%MOD
else:
    if q%2==0:
        ans = (-pow(4,q+1,MOD)*(A+C))%MOD
    else:
        ans = (pow(4,q+1,MOD)*(B+D))%MOD
print(ans)
            
            
            
        