# N = 100 # D = 3 def make_divisors(n): divisors = [] #必要に応じてsetにしても良いかも i = 1 while i ** 2 <= n: if n % i == 0: divisors.append(i) if i ** 2 != n: divisors.append(n//i) i += 1 divisors.sort() return divisors def check(x): print("?",x) return input() == "safe" # return x < N and x % D != 0 def search(lb,d): ub = 1000 while ub - lb > 1: mid = (ub + lb) // 2 if check(mid): lb = mid elif check(mid+1): lb = mid + 1 else: ub = mid return lb print("!",search(0,1000))