import sys,random,bisect from collections import deque,defaultdict from heapq import heapify,heappop,heappush from itertools import permutations from math import log,gcd 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 = -10 ng = log(12.22*10**74,10) for i in range(24): mid = (ok+ng)/2 if query(10**mid): ok = mid else: ng = mid answer(10**ok)