結果
問題 | No.1703 Much Matching |
ユーザー |
![]() |
提出日時 | 2021-10-08 22:55:42 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,289 ms / 2,000 ms |
コード長 | 418 bytes |
コンパイル時間 | 298 ms |
コンパイル使用メモリ | 82,532 KB |
実行使用メモリ | 194,336 KB |
最終ジャッジ日時 | 2024-07-23 06:08:13 |
合計ジャッジ時間 | 11,160 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 35 |
ソースコード
from bisect import bisect_left N, M, Q = map(int, input().split()) A = [list(map(int, input().split())) for _ in range(Q)] B = [0]*Q for i in range(Q): a, b = A[i] c = 2**10-1-b B[i] = a*(2**10)+c B.sort() INF = 10**9 dp = [INF]*(N+M+1) dp[0] = 0 for v in B: b = 2**10-1-(v % (2**10)) ind = bisect_left(dp, b) dp[ind] = min(dp[ind], b) ans = 0 while dp[ans+1] < INF: ans += 1 print(ans)