結果
問題 | No.1460 Max of Min |
ユーザー |
|
提出日時 | 2021-03-29 14:08:03 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,033 bytes |
コンパイル時間 | 104 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 22,144 KB |
最終ジャッジ日時 | 2024-11-29 09:56:20 |
合計ジャッジ時間 | 216,173 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 24 TLE * 67 |
ソースコード
INF=10**18+1 def check(X): b=[] for i in range(K-1,-1,-1): if B[i]>=X: b+=[K-i] if len(b)==0: return N<K and A[N]>=X M=b[0] dist=[INF for i in range(K+M)] seen=[False for i in range(K+M)] for i in range(K): if A[i]>=X: dist[i]=i for i in range(K+M): idx=-1 mn=INF+1 for j in range(K+M): if mn>dist[j] and (not seen[j]): idx=j mn=dist[j] seen[idx]=True for j in b: if idx<K: if idx+j>=K: dist[K+(idx+j)%M]=min(dist[K+(idx+j)%M],dist[idx]+j) else: dist[K+(idx-K+j)%M]=min(dist[K+(idx-K+j)%M],dist[idx]+j) if N<K: return dist[N]<=N else: return dist[K+N%M]<=N K,N=map(int,input().split()) A=list(map(int,input().split())) B=list(map(int,input().split())) ok=-INF ng=INF while ng-ok>1: mid=(ok+ng)//2 if check(mid): ok=mid else: ng=mid print(ok)