結果
問題 |
No.1331 Moving Penguin
|
ユーザー |
![]() |
提出日時 | 2021-01-08 22:11:30 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 707 bytes |
コンパイル時間 | 433 ms |
コンパイル使用メモリ | 82,304 KB |
実行使用メモリ | 177,152 KB |
最終ジャッジ日時 | 2024-11-16 12:36:11 |
合計ジャッジ時間 | 73,848 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 26 WA * 1 TLE * 22 |
ソースコード
mod = 1000000007 eps = 10**-9 def main(): import sys input = sys.stdin.readline N = int(input()) A = list(map(int, input().split())) add = [[0] * i for i in range(321)] ans = [0] * N ans[0] = 1 for i, a in enumerate(A): for d in range(1, 321): ans[i] = (ans[i] + add[d][i % d])%mod if a <= 320: add[a][i%a] = (add[a][i%a] + ans[i])%mod else: for j in range(1, N+1): if i+j >= N: break ans[i+j] = (ans[i+j] + ans[i])%mod if a != 1 and i+1 != N: ans[i+1] = (ans[i+1] + ans[i])%mod print(ans[-1]) if __name__ == '__main__': main()