結果
問題 | No.917 Make One With GCD |
ユーザー |
![]() |
提出日時 | 2022-04-24 11:22:51 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 94 ms / 2,000 ms |
コード長 | 472 bytes |
コンパイル時間 | 158 ms |
コンパイル使用メモリ | 82,360 KB |
実行使用メモリ | 76,544 KB |
最終ジャッジ日時 | 2024-06-25 21:42:31 |
合計ジャッジ時間 | 3,325 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 32 |
ソースコード
from collections import defaultdict def gcd(a, b): return a if b == 0 else gcd(b, a % b) N = int(input()) A = list(map(int, input().split())) # dp[i][j]: i番目までで最大公約数がjになる場合の数 dp = [defaultdict(int) for _ in range(N + 1)] for i in range(N): dp[i][A[i]] += 1 for j in range(i + 1, N): for k in dp[i].keys(): dp[j][gcd(k, A[j])] += dp[i][k] ans = 0 for i in range(N): ans += dp[i][1] print(ans)