# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
359252 | 2021-01-26T14:17:52 Z | Pety | Rice Hub (IOI11_ricehub) | C++14 | 0 ms | 0 KB |
#include <bits/stdc++.h> #include "ricehub.h" using namespace std; vector<int>sum, v; int cost (int l, int r) { int mij = (l + r) / 2; return v[mij] * (mij - l + 1) - (sum[mij] - sum[l - 1]) + (sum[r] - sum[mij - 1]) - (r - mij + 1) * v[mij]; } int besthub (int n, int l, vector<int>x, int b) { sum.resize(x.size()); v = x; for (int i = 0; i < x.size(); i++) sum[i] = (i ? sum[i - 1] + x[i] : x[i]); int sol = 0; for (int i = 0; i < n; i++) { int st = i, dr = n - 1, ans = 0; while (st <= dr) { int mij = (st + dr) / 2; if (cost(st, mij) <= b) { ans = mij; st = mij + 1; } else dr = mij - 1; } sol = max(sol, ans - i + 1); } return sol; } /*int main () { cout << besthub(5, 20, {1, 2, 10, 12, 14}, 6); return 0; }*/