# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
293092 | luciocf | The Big Prize (IOI17_prize) | C++14 | 96 ms | 2048 KiB |
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"
#define ff first
#define ss second
using namespace std;
typedef pair<int, int> pii;
const int maxn = 2e5+10;
pii val[maxn];
pii get(int i)
{
vector<int> v = ask(i);
return {v[0], v[1]};
}
int find_best(int n)
{
for (int i = 0; i < n; i++)
val[i] = {-1, -1};
int ind = 0;
int qtd = 0;
for (int i = 0; i < min(n, 500); i++)
{
pii v = get(i);
if (v.ff+v.ss == 0) return i;
if (v.ff+v.ss >= qtd)
qtd = v.ff+v.ss, ind = i;
}
int ant = ind;
val[ind] = get(ind);
for (int i = 1; i <= 500; i++)
{
int ini = ant+1, fim = n-1, ans;
while (ini <= fim)
{
int mid = (ini+fim)/2;
if (val[mid].ff == -1) val[mid] = get(mid);
if (val[mid].ff+val[mid].ss != qtd)
{
if (val[mid].ff+val[mid].ss == 0) return mid;
ans = mid, fim = mid-1;
}
else if (val[mid].ff-val[ind].ff-(i-1) > 0) fim = mid-1;
else ini = mid+1;
}
ant = ans;
}
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |