結果
| 問題 | No.16 累乗の加算 |
| コンテスト | |
| ユーザー |
koyopro
|
| 提出日時 | 2015-09-20 14:42:57 |
| 言語 | Python2 (2.7.18) |
| 結果 |
AC
|
| 実行時間 | 13 ms / 5,000 ms |
| コード長 | 528 bytes |
| コンパイル時間 | 77 ms |
| コンパイル使用メモリ | 7,040 KB |
| 実行使用メモリ | 6,272 KB |
| 最終ジャッジ日時 | 2024-06-26 05:02:06 |
| 合計ジャッジ時間 | 920 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 14 |
ソースコード
# -*- coding: utf-8 -*-
# x N
# a1 a2 … aN
x, N = map(int, raw_input().split())
mod = 1000003
mods = {}
powx2 = [x]
k = 0
border = 1
while 100000000 >= border:
powx2.append(powx2[k] ** 2 % mod)
k += 1
border *= 2
a = map(int, raw_input().split())
def powx(a):
totalmod = 1
for i in xrange(len(powx2)-1, -1, -1):
b = 2 ** i
if a >= b:
totalmod *= powx2[i]
a -= b
return totalmod
total = 0
for i in xrange(N):
total += powx(a[i])
print total % 1000003
koyopro