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 <bits/stdc++.h>
#include "prize.h"
using namespace std;
int find_best(int n) {
int sum = 0, pos = -1;
vector<int> ar;
int k = 400;
for(int i = 0 ; i < k ; i++)
{
ar = ask(i);
if(ar[0] + ar[1] == 0)
return i;
sum = max(sum, ar[0] + ar[1]);
}
pos = k - 1;
while(true)
{
pos++;
ar = ask(pos);
if(ar[0] + ar[1] == 0)
return pos;
if(ar[0] + ar[1] == sum)
break;
}
vector<vector<int>> query(n);
while(true)
{
for(int i = 17 ; i >= 0 ; i--)
{
int target = pos + (1<<i);
if(target < n)
{
if(query[target].empty())
query[target] = ask(target);
if(query[target][0] + query[target][1] == sum and query[target][1] == ar[1])
pos = target;
}
}
pos++;
while(true)
{
if(query[pos].empty())
query[pos] = ask(pos);
ar = query[pos];
if(ar[0] + ar[1] == 0)
return pos;
else if(ar[0] + ar[1] == sum)
break;
pos++;
}
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |