結果
| 問題 | No.995 タピオカオイシクナーレ |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-07-12 23:59:02 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 101 ms / 2,000 ms |
| コード長 | 632 bytes |
| コンパイル時間 | 312 ms |
| コンパイル使用メモリ | 82,848 KB |
| 実行使用メモリ | 78,192 KB |
| 最終ジャッジ日時 | 2024-06-23 22:10:58 |
| 合計ジャッジ時間 | 3,548 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 23 |
ソースコード
def modPow(a,n,mod):#繰り返し二乗法 a**n % mod
if n==0:
return 1
if n==1:
return a%mod
if n & 1:
return (a*modPow(a,n-1,mod)) % mod
t = modPow(a,n>>1,mod)
return (t*t)%mod
def invmod(a,mod):#mod逆元
if a == 0:
return 0
if a == 1:
return 1
return (-invmod(mod % a, mod) * (mod // a)) % mod
N,M,K,p,q = map(int,input().split())
lsb = [int(input()) for i in range(N)]
mod = 10**9+7
A0 = sum(lsb[:M])
B0 = sum(lsb[M:])
#2An = (1-2*p/q)**n*(A0-B0)+A0+B0
ans = ((modPow(q-2*p,K,mod)*modPow(invmod(q,mod),K,mod)*(A0-B0)+A0+B0)*invmod(2,mod)) % mod
print(ans)