結果
| 問題 | No.979 Longest Divisor Sequence |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-08-31 15:50:01 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 428 ms / 2,000 ms |
| コード長 | 391 bytes |
| 記録 | |
| コンパイル時間 | 538 ms |
| コンパイル使用メモリ | 85,376 KB |
| 実行使用メモリ | 179,932 KB |
| 最終ジャッジ日時 | 2026-05-08 15:10:44 |
| 合計ジャッジ時間 | 3,050 ms |
|
ジャッジサーバーID (参考情報) |
judge3_1 / judge1_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| 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))