Submission #760617

#TimeUsernameProblemLanguageResultExecution timeMemory
760617SanguineChameleonRice Hub (IOI11_ricehub)C++17
17 / 100
166 ms1852 KiB
#include "ricehub.h" #include <bits/stdc++.h> using namespace std; const int maxN = 1e5 + 20; int a[maxN]; long long pref[maxN]; int besthub(int N, int L, int X[], long long B) { for (int i = 1; i <= N; i++) { a[i] = X[i - 1]; pref[i] = pref[i - 1] + a[i]; } sort(a + 1, a + N + 1); int res = 0; for (int i = 1; i <= N; i++) { int lt = 0; int rt = L; while (lt <= rt) { int mt = (lt + rt) / 2; int li = lower_bound(a + 1, a + N + 1, a[i] - mt) - a; int ri = upper_bound(a + 1, a + N + 1, a[i] + mt) - a - 1; long long cost_l = 1LL * a[i] * (i - li) - (pref[i - 1] - pref[li - 1]); long long cost_r = (pref[ri] - pref[i]) - 1LL * a[i] * (ri - i); if (cost_l + cost_r <= B) { res = max(res, ri - li + 1); lt = mt + 1; } else { rt = mt - 1; } } } 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...