結果
問題 |
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)