#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const int inf=1<<30; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-8; const ull mod=1e9+7; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; int Q(int x){ cout<<"? "<>t; return t; } int f(){ for(int i=0;i<50;i++){ int t=Q(i+11); if(t==0) return 2*i+11; if(t==-1) return 2*i+10; } int l=40,r=inf,i=0; while(r-l>1){ int m=(l+r)/2,t=Q(m-i); if(t>=0) l=m; else r=m; i++; } return l+50; } int main(){ cout<<"! "<