309342: CF1665D. GCD Guess

Memory Limit:256 MB Time Limit:3 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

GCD Guess

题意翻译

感谢@[cff_0102](https://www.luogu.com.cn/user/542457) 提供翻译。 这是一道交互题。 有一个正整数 $1 \le x \le 10^9$,你必须将它猜出来。 每次查询,你可以选择两个数 $a \neq b$,你会从交互库得到 $\gcd(x + a, x + b)$。 你要在 $30$ 次猜测之内得到 $x$。 ### 交互格式 第一行输入一个整数 $1\le t\le 1000$,表示测试用例的数量,即猜测次数。 每次猜测时格式为 `? a b`,此时你将得到 $\gcd(x + a, x + b)$。 当你确定答案,你可以输出 `! x`,然后继续解决下一个测试用例。

题目描述

This is an interactive problem. There is a positive integer $ 1 \le x \le 10^9 $ that you have to guess. In one query you can choose two positive integers $ a \neq b $ . As an answer to this query you will get $ \gcd(x + a, x + b) $ , where $ \gcd(n, m) $ is the [greatest common divisor](<https://en.wikipedia.org/wiki/Greatest common divisor>) of the numbers $ n $ and $ m $ . To guess one hidden number $ x $ you are allowed to make no more than $ 30 $ queries.

输入输出格式

输入格式


The first line of input contains a single integer $ t $ ( $ 1 \le t \le 1000 $ ) denoting the number of test cases. The integer $ x $ that you have to guess satisfies the constraints: ( $ 1 \le x \le 10^9 $ ).

输出格式


The hidden number $ x $ is fixed before the start of the interaction and does not depend on your queries. To guess each $ x $ you can make no more than $ 30 $ queries in the following way: - "? a b" ( $ 1 \le a, b \le 2 \cdot 10^9 $ , $ a \neq b $ ). For this query you will get $ \gcd(x + a, x + b) $ . When you know $ x $ , print a single line in the following format. - "! x" ( $ 1 \le x \le 10^9 $ ). After that continue to solve the next test case. If you ask more than $ 30 $ queries for one $ x $ or make an invalid query, the interactor will terminate immediately and your program will receive verdict Wrong Answer. After printing each query do not forget to output end of line and flush the output buffer. Otherwise, you will get the Idleness limit exceeded verdict. To do flush use: - fflush(stdout) or cout.flush() in C++; - System.out.flush() in Java; - flush(output) in Pascal; - stdout.flush() in Python; - Read documentation for other languages. Hacks To use hacks, use the following format of tests: The first line should contain a single integer $ t $ ( $ 1 \le t \le 1000 $ ) — the number of test cases. The first and only line of each test case should contain a single integer $ x $ ( $ 1 \le x \le 10^9 $ ) denoting the integer $ x $ that should be guessed.

输入输出样例

输入样例 #1

2

1

8


1

输出样例 #1

? 1 2

? 12 4

! 4
? 2000000000 1999999999

! 1000000000

说明

The first hidden number is $ 4 $ , that's why the answers for the queries are: "? 1 2" — $ \gcd(4 + 1, 4 + 2) = \gcd(5, 6) = 1 $ . "? 12 4" — $ \gcd(4 + 12, 4 + 4) = \gcd(16, 8) = 8 $ . The second hidden number is $ 10^9 $ , that's why the answer for the query is: "? 2000000000 1999999999" — $ \gcd(3 \cdot 10^9, 3 \cdot 10^9 - 1) = 1 $ . These queries are made only for understanding the interaction and are not enough for finding the true $ x $ .

Input

题意翻译

感谢@[cff_0102](https://www.luogu.com.cn/user/542457) 提供翻译。 这是一道交互题。 有一个正整数 $1 \le x \le 10^9$,你必须将它猜出来。 每次查询,你可以选择两个数 $a \neq b$,你会从交互库得到 $\gcd(x + a, x + b)$。 你要在 $30$ 次猜测之内得到 $x$。 ### 交互格式 第一行输入一个整数 $1\le t\le 1000$,表示测试用例的数量,即猜测次数。 每次猜测时格式为 `? a b`,此时你将得到 $\gcd(x + a, x + b)$。 当你确定答案,你可以输出 `! x`,然后继续解决下一个测试用例。

加入题单

算法标签: