結果
問題 |
No.1804 Intersection of LIS
|
ユーザー |
|
提出日時 | 2021-09-20 11:46:46 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 1,008 bytes |
コンパイル時間 | 274 ms |
コンパイル使用メモリ | 82,236 KB |
実行使用メモリ | 120,764 KB |
最終ジャッジ日時 | 2024-11-14 08:11:36 |
合計ジャッジ時間 | 12,822 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 RE * 2 |
other | AC * 3 RE * 34 |
ソースコード
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 n = int(input()) p = list(map(int, input().split())) leng, lis_min = lis(p) _, lis_max = lds(p[::-1]) lis_max = lis_max[::-1][:leng][::-1] ans = [] for i in range(len(lis_min)): if lis_min[i] == lis_max[i]: ans2.append(lis_min[i]) print(len(ans)) print(*ans)