結果
問題 |
No.1804 Intersection of LIS
|
ユーザー |
|
提出日時 | 2021-09-20 02:46:38 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,018 bytes |
コンパイル時間 | 291 ms |
コンパイル使用メモリ | 82,160 KB |
実行使用メモリ | 114,140 KB |
最終ジャッジ日時 | 2024-11-14 08:09:53 |
合計ジャッジ時間 | 5,031 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 7 WA * 29 RE * 1 |
ソースコード
from bisect import * INF = 10 ** 9 def lis(x): dp = [INF] * (len(x) + 1) id = [0] * len(x) for i in range(len(x)): id[i] = bisect_left(dp, x[i]) dp[bisect_left(dp, x[i])] = x[i] m = max(id) b = [0] * (m + 1) for i in range(len(x) - 1, -1, -1): if id[i] == m: b[m] = x[i] m -= 1 return bisect_left(dp, INF), b def lds(x): dp = [-INF] * (len(x) + 1) id = [0] * len(x) for i in range(len(x)): id[i] = bisect_left(dp, x[i]) - 1 dp[bisect_left(dp, x[i]) - 1] = x[i] m = min(id) b = [0] * (max(id) + 1) for i in range(len(x))[::-1]: if id[i] == m: b[m] = x[i] m += 1 return dp[::-1].index(-INF), b import random n = int(input()) p = list(map(int, input().split())) if n > 2000: exit() leng, lis1 = lis(p) ans = [] cur = 0 for i in range(n): a2 = p[:i] + p[i + 1:] new_leng, _ = lis(a2) if leng != new_leng: ans.append(p[i]) print(len(ans)) print(*ans)