#D13111. Ehab and another another xor problem
Ehab and another another xor problem
Ehab and another another xor problem
This is an interactive problem!
Ehab plays a game with Laggy. Ehab has 2 hidden integers (a,b). Laggy can ask a pair of integers (c,d) and Ehab will reply with:
- 1 if a ⊕ c>b ⊕ d.
- 0 if a ⊕ c=b ⊕ d.
- -1 if a ⊕ c<b ⊕ d.
Operation a ⊕ b is the bitwise-xor operation of two numbers a and b.
Laggy should guess (a,b) with at most 62 questions. You'll play this game. You're Laggy and the interactor is Ehab.
It's guaranteed that 0 ≤ a,b<2^{30}.
Input
See the interaction section.
Output
To print the answer, print "! a b" (without quotes). Don't forget to flush the output after printing the answer.
Interaction
To ask a question, print "? c d" (without quotes). Both c and d must be non-negative integers less than 2^{30}. Don't forget to flush the output after printing any question.
After each question, you should read the answer as mentioned in the legend. If the interactor replies with -2, that means you asked more than 62 queries and your program should terminate.
To flush the output, you can use:-
- fflush(stdout) in C++.
- System.out.flush() in Java.
- stdout.flush() in Python.
- flush(output) in Pascal.
- See the documentation for other languages.
Hacking:
To hack someone, print the 2 space-separated integers a and b (0 ≤ a,b<2^{30}).
Example
Input
1 -1 0
Output
? 2 1 ? 1 2 ? 2 0 ! 3 1
Note
In the sample:
The hidden numbers are a=3 and b=1.
In the first query: 3 ⊕ 2 = 1 and 1 ⊕ 1 = 0, so the answer is 1.
In the second query: 3 ⊕ 1 = 2 and 1 ⊕ 2 = 3, so the answer is -1.
In the third query: 3 ⊕ 2 = 1 and 1 ⊕ 0 = 1, so the answer is 0.
Then, we printed the answer.
inputFormat
Input
See the interaction section.
outputFormat
Output
To print the answer, print "! a b" (without quotes). Don't forget to flush the output after printing the answer.
Interaction
To ask a question, print "? c d" (without quotes). Both c and d must be non-negative integers less than 2^{30}. Don't forget to flush the output after printing any question.
After each question, you should read the answer as mentioned in the legend. If the interactor replies with -2, that means you asked more than 62 queries and your program should terminate.
To flush the output, you can use:-
- fflush(stdout) in C++.
- System.out.flush() in Java.
- stdout.flush() in Python.
- flush(output) in Pascal.
- See the documentation for other languages.
Hacking:
To hack someone, print the 2 space-separated integers a and b (0 ≤ a,b<2^{30}).
Example
Input
1 -1 0
Output
? 2 1 ? 1 2 ? 2 0 ! 3 1
Note
In the sample:
The hidden numbers are a=3 and b=1.
In the first query: 3 ⊕ 2 = 1 and 1 ⊕ 1 = 0, so the answer is 1.
In the second query: 3 ⊕ 1 = 2 and 1 ⊕ 2 = 3, so the answer is -1.
In the third query: 3 ⊕ 2 = 1 and 1 ⊕ 0 = 1, so the answer is 0.
Then, we printed the answer.
样例
1
-1
0
? 0 0
? 536870912 0
? 0 536870912
? 805306368 536870912
? 536870912 805306368
? 939524096 536870912
? 805306368 671088640
? 872415232 671088640
? 805306368 738197504
? 838860800 738197504
? 805306368 771751936
? 822083584 771751936
? 805306368 788529152
? 813694976 788529152
? 805306368 796917760
? 809500672 796917760
? 805306368 801112064
? 807403520 801112064
? 805306368 803209216
? 806354944 803209216
? 805306368 804257792
? 805830656 804257792
? 805306368 804782080
? 805568512 804782080
? 805306368 805044224
? 805437440 805044224
? 805306368 805175296
? 805371904 805175296
? 805306368 805240832
? 805339136 805240832
? 805306368 805273600
? 805322752 805273600
? 805306368 805289984
? 805314560 805289984
? 805306368 805298176
? 805310464 805298176
? 805306368 805302272
? 805308416 805302272
? 805306368 805304320
? 805307392 805304320
? 805306368 805305344
? 805306880 805305344
? 805306368 805305856
? 805306624 805305856
? 805306368 805306112
? 805306496 805306112
? 805306368 805306240
? 805306432 805306240
? 805306368 805306304
? 805306400 805306304
? 805306368 805306336
? 805306384 805306336
? 805306368 805306352
? 805306376 805306352
? 805306368 805306360
? 805306372 805306360
? 805306368 805306364
? 805306370 805306364
? 805306368 805306366
? 805306369 805306366
? 805306368 805306367
! 805306368 805306367
</p>