結果
問題 | No.1597 Matrix Sort |
ユーザー |
![]() |
提出日時 | 2023-11-24 07:49:34 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 330 ms / 1,500 ms |
コード長 | 522 bytes |
コンパイル時間 | 204 ms |
コンパイル使用メモリ | 82,048 KB |
実行使用メモリ | 181,632 KB |
最終ジャッジ日時 | 2024-09-26 08:32:05 |
合計ジャッジ時間 | 7,215 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 27 |
ソースコード
import sys input = lambda: sys.stdin.readline().strip() import bisect N,K,P = map(int,input().split()) A = list(map(int,input().split())) B = list(map(int,input().split())) R = [0 for i in range(P)] for a in A: R[a] += 1 for i in range(P-1): R[i+1] += R[i] l = -1 r = P - 1 while r - l > 1: m = (l + r) // 2 res = 0 for b in B: # a + b は 0 ~ 2*P - 1. m,m+P if m - b >= 0: res += R[m-b] x = min(P + m - b,P - 1) res += (R[x] - R[P-1-b]) if res < K: l = m else: r = m print(r)