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;
#define ll long long
set<ll> st;
ll pos = 0, ans = 1e18;
bool ask(ll n){
cout << "? " << n << endl;
st.insert(n);
int res;
cin >> res;
if(res){
ans = min(ans, abs(n-pos));
}
pos = n;
return (res == 1);
}
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
ll n;
cin >> n;
ans = n;
if(n <= 64){
ll l = 1, r = n+1;
ask(1);
for(int x=1;x<n;x++){
if(x&1){
r--;
if(ask(r)){
ans = min(ans, r-l);
}
} else {
l++;
if(ask(l)){
ans = min(ans, r-l);
}
}
}
cout << "= " << ans << endl;
return 0;
}
ll left = (n%2), right = (n+1)/2-1;
while(left <= right){
ll mid = (left+right) >> 1;
ll pL = (n%2 == 0 ? n/2-mid : (n+1)/2-mid);
ll pR = (n%2 == 0 ? n/2+1+mid : (n+1)/2+mid);
ask(pL);
if(ask(pR)){
ans = min(ans, pR-pL);
right = mid-1;
} else {
left = mid+1;
}
}
ll prv = ans;
for(int i=1;i<=3;i++){
bool valid = false;
for(ll x=1;x<=n;x++){
if(prv-i <= 0) break;
if(!st.count(x) && !st.count(x+prv-i) && x+prv-i <= n){
ask(x);
if(ask(x+prv-i)){
valid = true;
}
break;
}
}
if(!valid) break;
}
cout << "= " << ans << endl;
return 0;
}
# | 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... |