結果
問題 |
No.1995 CHIKA Road
|
ユーザー |
![]() |
提出日時 | 2022-10-10 21:03:56 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 481 ms / 2,000 ms |
コード長 | 445 bytes |
コンパイル時間 | 179 ms |
コンパイル使用メモリ | 81,920 KB |
実行使用メモリ | 158,720 KB |
最終ジャッジ日時 | 2024-06-24 17:58:46 |
合計ジャッジ時間 | 10,698 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 37 |
ソースコード
N, M = map(int, (input().split())) AB = [list(map(int, input().split())) for _ in range(M)] S = set() for a, b in AB: S.add(a) S.add(b) B = sorted(list(S)) D = dict(zip(B, range(len(B)))) NB = len(B) dp = [0] * (NB) AB.sort(key=lambda x: x[1]) k = 0 for i in range(1, NB): b = B[i] dp[i] = dp[i - 1] while k < M and AB[k][1] == b: dp[i] = max(dp[i], dp[D[AB[k][0]]] + 1) k += 1 print(2 * N - dp[NB - 1] - 2)