結果
| 問題 |
No.979 Longest Divisor Sequence
|
| ユーザー |
|
| 提出日時 | 2022-08-31 15:50:01 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 1,339 ms / 2,000 ms |
| コード長 | 391 bytes |
| コンパイル時間 | 205 ms |
| コンパイル使用メモリ | 82,176 KB |
| 実行使用メモリ | 194,160 KB |
| 最終ジャッジ日時 | 2024-11-08 09:13:52 |
| 合計ジャッジ時間 | 7,037 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 16 |
ソースコード
import sys
input = sys.stdin.buffer.readline
N = int(input())
A = tuple(map(int, input().split()))
MAX = max(A)
INF = 100
divisors = [[] for _ in range(MAX + 1)]
for i in range(1, MAX + 1):
for j in range(i * 2, MAX + 1, i):
divisors[j].append(i)
dp = [-INF] * (MAX + 1)
for a in A:
dp[a] = 1
for x in divisors[a]:
dp[a] = max(dp[a], dp[x] + 1)
print(max(dp))