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>
using namespace std;
pair< long long,long long > st;
pair< long long,long long > lft;
pair< long long,long long > rgt;
pair< long long,long long > up;
pair< long long,long long > lftup;
bool ask(pair< long long,long long > a,bool ret = false)
{
cout << "examine " << a.first << " " << a.second << endl;
cin >> ret;
return ret;
}
void ans(pair< long long,long long > a)
{
cout<<"solution "<<a.first<<" "<<a.second<<endl;
}
int main()
{
long long n,big;
cin >> n >> st.first >> st.second;
//get up
up = st,big = -1;
for(long long i=0;i<=32;i++)
{
if(up.second+(1ll<<i)>n||!ask({up.first,up.second+(1ll<<i)})) break;
big = i;
}
if(big!=-1) up.second+=(1ll<<big);
for(long long i=big-1;i>=0;i--)
{
if(up.second+(1ll<<i)>n||!ask({up.first,up.second+(1ll<<i)})) continue;
up.second+=(1ll<<i);
}
//get right
rgt = st,big = -1;
for(long long i=0;i<=32;i++)
{
if(rgt.first+(1ll<<i)>n||!ask({rgt.first+(1ll<<i),rgt.second})) break;
big = i;
}
if(big!=-1) rgt.first+=(1ll<<big);
for(long long i=big-1;i>=0;i--)
{
if(rgt.first+(1ll<<i)>n||!ask({rgt.first+(1ll<<i),rgt.second})) continue;
rgt.first+=(1ll<<i);
}
//get left
lft = st,big = -1;
for(long long i=0;i<=32;i++)
{
if(lft.first-(1ll<<i)<=0||!ask({lft.first-(1ll<<i),lft.second})) break;
big = i;
}
if(big!=-1) lft.first-=(1ll<<big);
for(long long i=big-1;i>=0;i--)
{
if(lft.first-(1ll<<i)<=0||!ask({lft.first-(1ll<<i),lft.second})) continue;
lft.first-=(1ll<<i);
}
long long m = rgt.first-lft.first+1;
lftup = {lft.first,up.second};
while(1)
{
if(lftup.first-2*m<=0||!ask({lftup.first-2*m,lftup.second})) break;
lftup.first-=2*m;
}
while(1)
{
if(lftup.second+2*m>n||!ask({lftup.first,lftup.second+2*m})) break;
lftup.second+=2*m;
}
ans({lftup.first+2*m+m/2,lftup.second-2*m-m/2});
return 0;
}
/*
19 7 4
examine 7 5
0
examine 8 4
0
examine 6 4
1
examine 5 4
1
examine 3 4
0
examine 4 4
0
examine 5 10
1
examine 5 16
1
*/
# | 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... |
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |