#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define rep(i,a) for(int i=(int)0;i<(int)a;++i) #define pb push_back #define eb emplace_back using ll=long long; constexpr ll mod = 1e9 + 7; constexpr ll INF = 1LL << 50; template inline bool chmin(T& a, T b) { if (a > b) { a = b; return true; } return false; } template inline bool chmax(T& a, T b) { if (a < b) { a = b; return true; } return false; } using namespace std; ll C(ll mid){ cout<<"? "<>res; return res; } void solve(){ ll l=0,r=1e9; ll cnt=0; rep(i,100){ ll mid=(l+r)/2; ll x=C(mid-cnt); if(x==1)r=mid; else if(x==-1)l=mid; else { cout<<"! "<