結果
問題 | No.1097 Remainder Operation |
ユーザー |
![]() |
提出日時 | 2020-12-22 18:37:05 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 374 ms / 2,000 ms |
コード長 | 703 bytes |
コンパイル時間 | 323 ms |
コンパイル使用メモリ | 82,184 KB |
実行使用メモリ | 121,508 KB |
最終ジャッジ日時 | 2024-09-21 14:16:33 |
合計ジャッジ時間 | 7,871 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 21 |
ソースコード
mod = 1000000007 eps = 10**-9 def main(): import sys input = sys.stdin.buffer.readline N = int(input()) A = list(map(int, input().split())) nxt = [[0] * N for _ in range(41)] for i in range(N): nxt[0][i] = A[i] for lv in range(1, 41): for i in range(N): tmp = nxt[lv-1][i] j = (i + tmp)%N nxt[lv][i] = tmp + nxt[lv-1][j] for _ in range(int(input())): k = int(input()) i = 0 ans = 0 for lv in range(41): if k >> lv & 1: tmp = nxt[lv][i] ans += tmp i = (i + tmp)%N print(ans) if __name__ == '__main__': main()