제출 #655511

#제출 시각아이디문제언어결과실행 시간메모리
655511PanTkdRice Hub (IOI11_ricehub)C++14
100 / 100
24 ms708 KiB
#include "ricehub.h" #include <iostream> #include <cmath> typedef long long ll; using namespace std; bool ok (ll x, int R,int L,int X[],long long B){ ll i = x; ll cost = 0; ll med = ((i)/2); for(ll j = 0;j<i;j++){ cost += abs(X[med]-X[j]); } if(cost<=B){ return 1;} for(ll j = 1;j<=R-i;j++){ med++; cost += (i/2-(i-1)/2)*(X[med]-X[med-1]); cost += abs(X[med]-X[j+i-1]); cost -= abs(X[med-1]-X[j-1]); if(cost<=B){return 1;} } return 0; } int besthub(int R, int L, int X[], long long B) { ll l = 1 ; ll r = R; ll ans = 1; while(l<=r){ ll m = (l+r)>>1; if (ok(m,R,L,X,B)) { ans = max (ans, m); l = m+1; } else{ r = m - 1; } } return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...