제출 #563307

#제출 시각아이디문제언어결과실행 시간메모리
5633071neRice Hub (IOI11_ricehub)C++14
0 / 100
3 ms596 KiB
#include "ricehub.h" #include<bits/stdc++.h> using namespace std; int besthub(int R, int L, int X[], long long B) { int ans = 0; vector<int64_t>pref(R + 1,0),dpref(R + 1,0); for (int i = 0 ;i<R - 1;++i){ pref[i + 1] = pref[i] + (X[i + 1] - X[i]); dpref[i + 2] = pref[i + 1] + dpref[i + 1]; } //for (int i = 0;i<R;++i)cout<<dpref[i]<<" "; //cout<<'\n'; //1 3 18 - auto dist = [&](int l,int r){ return pref[r] * (r - l) - dpref[r] + dpref[l]; }; for (int i = 0;i<R;++i){ int l = 0; int left = 0,right = i; while(left<=right){ int mid = (left + right)>>1; if (dist(mid,i)<=B){ l = mid; right = mid - 1; } else left = mid + 1; } ans = max(ans,i - l + 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...