#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define popcount __builtin_popcount using namespace std; using namespace atcoder; typedef long long ll; typedef pair P; using mint=modint998244353; bool query(double x){ printf("? %.10Lf\n", x); fflush(stdout); string res; cin>>res; return res=="Yes"; } long double v[(3<<23)+1]; int main() { long double y=0; for(int i=0; i<=(3<<23); i++){ v[i]=y; if(y<1.0L) y+=0.000009L; else y*=1.000009L; } //printf("! %.8Lf\n", v[(3<<23)]); //printf("! %.8Lf\n", v[(3<<23)-1]);return 0; int t;cin>>t; while(t--){ int l=0, r=(3<<23); for(int i=0; i<24; i++){ int m=(l+r)/2; if(query(v[m])) l=m; else r=m; } printf("! %.10Lf\n", v[(l+r)/2]); fflush(stdout); } return 0; }