import sys,random,bisect from collections import deque,defaultdict from heapq import heapify,heappop,heappush from itertools import permutations from math import log,gcd from fractions import Fraction input = lambda :sys.stdin.readline().rstrip() mi = lambda :map(int,input().split()) li = lambda :list(mi()) def query(y): if y < 100: print("? {:.100f}".format(y)) else: print("? {:.100g}".format(y)) sys.stdout.flush() return True res = input() assert res!="-1" return res=="Yes" def answer(x): if x < 100: print("! {:.100f}".format(x)) else: print("! {:.100g}".format(x)) sys.stdout.flush() for _ in range(int(input())): ok = Fraction(-10) ng = Fraction(log(12.22,10) + 74) for i in range(24): mid = (ok+ng)/2 if query(10**mid): ok = mid else: ng = mid answer(10**ok)