結果
問題 |
No.1804 Intersection of LIS
|
ユーザー |
|
提出日時 | 2021-10-01 12:54:01 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 513 ms / 2,000 ms |
コード長 | 727 bytes |
コンパイル時間 | 432 ms |
コンパイル使用メモリ | 82,248 KB |
実行使用メモリ | 148,816 KB |
最終ジャッジ日時 | 2024-11-14 08:15:25 |
合計ジャッジ時間 | 10,526 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 37 |
ソースコード
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): l = [] for i in x: l.append(-i) return lis(l) n = int(input()) p = list(map(int, input().split())) leng, lis_min = lis(p) _, lis_max = lds(p[::-1]) lis_max = [-i for i in lis_max][::-1] ans = [] for i in range(len(lis_min)): if lis_min[i] == lis_max[i]: ans.append(lis_min[i]) print(len(ans)) print(*ans)