結果
| 問題 | No.3513 Greedy Yokan Party |
| コンテスト | |
| ユーザー |
tau1235
|
| 提出日時 | 2026-04-24 21:45:31 |
| 言語 | C++23 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 661 bytes |
| 記録 | |
| コンパイル時間 | 2,635 ms |
| コンパイル使用メモリ | 334,632 KB |
| 実行使用メモリ | 6,528 KB |
| 最終ジャッジ日時 | 2026-04-24 21:45:48 |
| 合計ジャッジ時間 | 5,521 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | WA * 26 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
int main(){
using ll=long long;
ll inf=1e18;
ll n,l,k;
cin>>n>>l>>k;
vector<ll> a(n+1);
a[0]=0;
for (int i=1;i<=n;i++) cin>>a[i];
a.push_back(l);
a.push_back(inf);
auto f=[&](ll x){
vector<ll> g(n+3,inf);
ll mval=inf;
int r=0;
ll len=0;
ll mcnt=-inf;
for (int i=0;i<=n;i++){
while (a[r]-a[i]<x) r++;
if (r==n+2) break;
g[r]=min(g[r],(ll)r-i);
mval=min(mval,g[i]);
mcnt=max(mcnt,n+1-(mval+r-i));
}
return mcnt>=k-1;
};
ll L=0,R=10;
while (R-L>1){
ll mid=(L+R)/2;
if (f(mid)) L=mid;
else R=mid;
}
cout<<L<<endl;
}
tau1235