結果
問題 |
No.1804 Intersection of LIS
|
ユーザー |
|
提出日時 | 2021-11-20 16:41:52 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 947 ms / 2,000 ms |
コード長 | 727 bytes |
コンパイル時間 | 508 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 57,420 KB |
最終ジャッジ日時 | 2024-11-14 08:14:50 |
合計ジャッジ時間 | 16,040 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
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)