結果

問題 No.995 タピオカオイシクナーレ
ユーザー brthyyjpbrthyyjp
提出日時 2020-02-21 22:59:18
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 77 ms / 2,000 ms
コード長 655 bytes
コンパイル時間 153 ms
コンパイル使用メモリ 82,488 KB
実行使用メモリ 76,704 KB
最終ジャッジ日時 2024-04-17 08:05:50
合計ジャッジ時間 2,418 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 36 ms
52,480 KB
testcase_01 AC 37 ms
52,224 KB
testcase_02 AC 38 ms
52,224 KB
testcase_03 AC 37 ms
51,968 KB
testcase_04 AC 37 ms
52,608 KB
testcase_05 AC 37 ms
52,224 KB
testcase_06 AC 37 ms
52,224 KB
testcase_07 AC 36 ms
51,840 KB
testcase_08 AC 39 ms
51,840 KB
testcase_09 AC 36 ms
52,224 KB
testcase_10 AC 37 ms
52,352 KB
testcase_11 AC 39 ms
53,120 KB
testcase_12 AC 38 ms
52,736 KB
testcase_13 AC 37 ms
52,736 KB
testcase_14 AC 38 ms
52,480 KB
testcase_15 AC 42 ms
52,992 KB
testcase_16 AC 75 ms
76,516 KB
testcase_17 AC 77 ms
76,288 KB
testcase_18 AC 70 ms
76,676 KB
testcase_19 AC 71 ms
76,288 KB
testcase_20 AC 71 ms
76,416 KB
testcase_21 AC 72 ms
76,544 KB
testcase_22 AC 71 ms
76,476 KB
testcase_23 AC 70 ms
76,544 KB
testcase_24 AC 71 ms
76,456 KB
testcase_25 AC 69 ms
76,704 KB
権限があれば一括ダウンロードができます

ソースコード

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