This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "ricehub.h"
#include<bits/stdc++.h>
using namespace std;
#define ll long long
int besthub(int R, int L, int X[], long long B){
queue<int> l, r;
for (int i=0; i<R; i++) r.push(X[i]);
int bsf = 0, curl = 0, curr = 0, i = 0;
ll k = 0;
while (true){
while (!l.empty() && !r.empty() && curl && (r.front()-X[i]) < (X[i]-l.front())){
//cout << "b\n";
k += r.front()+l.front()-2*X[i];
l.pop();
l.push(r.front());
r.pop();
curl--;
curr++;
}
//cout << k << " " << r.front() << " " << X[i] << " " << B << "\n";
while (!r.empty() && ((k+(r.front()-X[i])) <= B)){
//cout << "a\n";
k += r.front()-X[i];
l.push(r.front());
r.pop();
curr++;
}
if (k <= B) bsf = max(bsf, curl+curr);
//cout << i << " " << curl << " " << curr << " " << k << " " << bsf << "\n";
i++;
if (i == R) break;
curl++; curr--;
k += (curl-curr)*(X[i]-X[i-1]);
}
return bsf;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |