Submission #562258

#TimeUsernameProblemLanguageResultExecution timeMemory
562258four_specksRice Hub (IOI11_ricehub)C++17
100 / 100
25 ms3332 KiB
#include "ricehub.h" #include <bits/stdc++.h> using namespace std; namespace { } // namespace int besthub(int R, int L, int X[], long long B) { vector<long> pref(R + 1, 0), suff(R + 1, 0); for (int i = 0; i < R; i++) pref[i + 1] = pref[i] + X[i]; for (int i = R - 1; i >= 0; i--) suff[i] = suff[i + 1] - X[i]; cerr << pref[3] << '\n'; int res = 0; for (int i = 0; i < R; i++) { int lo = i, hi = R; while (lo < hi) { int mid = (lo + hi + 1) / 2; int m = (i + mid) / 2; // cerr << i << ' ' << mid << ' ' << m << ' ' << pref[mid] - pref[m] << ' ' << suff[i] - suff[m] << ' ' << (long)(mid - i) * X[m] << '\n'; if (pref[mid] - pref[m] + suff[i] - suff[m] - (long)(mid - m) * X[m] - (long)(m - i) * -X[m] <= B) lo = mid; else hi = mid - 1; } res = max(res, lo - i); } return res; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...