結果
問題 | No.1460 Max of Min |
ユーザー |
|
提出日時 | 2021-03-29 14:08:22 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,074 ms / 2,000 ms |
コード長 | 1,085 bytes |
コンパイル時間 | 231 ms |
コンパイル使用メモリ | 82,228 KB |
実行使用メモリ | 76,888 KB |
最終ジャッジ日時 | 2024-11-30 01:51:11 |
合計ジャッジ時間 | 40,173 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 91 |
ソースコード
INF=10**18+1; #bool chmin(ll&a,ll b){return a>b?a=b,true:false;} 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)