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 "gap.h"
#include<bits/stdc++.h>
using namespace std;
#define f first
#define s second
typedef long long ll;
long long findGap(int T, int N)
{
ll l, r, ans = 0, n = N;
MinMax(0, 1e18, &l, &r);
if(T==1){
for(int i = 0; i < (n-1)/2; i++){
ll nxtl, nxtr;
MinMax(l+1, r-1, &nxtl, &nxtr);
ans = max(ans, nxtl-l);
ans = max(ans, r-nxtr);
l = nxtl;
r = nxtr;
}
ans = max(ans, r-l);
}
else{
vector<pair<ll, ll>> vec;
ll dist = (r-l-1)/n + !!((r-l-1)%n);
for(ll i = l+1; i < r; i+=dist){
ll rb = min(r-1, i+dist-1);
pair<ll, ll> tmp;
MinMax(i, rb, &tmp.f, &tmp.s);
if(tmp.f >= 0)vec.push_back(tmp);
}
if(vec.empty())ans = r-l;
else{
ans = max(vec[0].f - l, r-vec.back().s);
for(int i = 1; i < vec.size(); i++){
ans = max(ans, vec[i].f - vec[i-1].s);
}
}
}
return ans;
}
Compilation message (stderr)
gap.cpp: In function 'long long int findGap(int, int)':
gap.cpp:38:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
38 | for(int i = 1; i < vec.size(); i++){
| ~~^~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |