結果

問題 No.995 タピオカオイシクナーレ
ユーザー brthyyjp
提出日時 2020-02-21 22:59:18
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 77 ms / 2,000 ms
コード長 655 bytes
コンパイル時間 301 ms
コンパイル使用メモリ 82,248 KB
実行使用メモリ 76,544 KB
最終ジャッジ日時 2024-10-08 22:43:51
合計ジャッジ時間 2,881 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 23
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
input = sys.stdin.readline

n, m, k, p, q = map(int, input().split())
l = [int(input()) for _ in range(n)]
s0 = 0
s1 = 0
for i in range(n):
    if i <= m-1:
        s0 += l[i]
    else:
        s1 += l[i]

def power_func(a,n,p):
  bi=str(format(n,"b"))#2進表現に
  res=1
  for i in range(len(bi)):
    res=(res*res) %p
    if bi[i]=="1":
      res=(res*a) %p
  return res

mod = 10**9+7
x = (power_func(q,k,mod) + power_func(q-2*p,k,mod))*s0 + (power_func(q,k,mod) - power_func(q-2*p,k,mod))*s1
#x = (q**k+(q-2*p)**k)*s0 + (q**k-(q-2*p)**k)*s1
y = 2*power_func(q,k,mod)
#y = 2*q**k
mod = 10**9+7
#print(x/y)
print(x*pow(y,(mod-2),mod)%mod)
0