Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

C. Guess the Array

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputThis is an interactive problem. You should use flush operation after each printed line. For example, in C++ you should use fflush(stdout), in Java you should use System.out.flush(), and in Pascal — flush(output).

In this problem you should guess an array *a* which is unknown for you. The only information you have initially is the length *n* of the array *a*.

The only allowed action is to ask the sum of two elements by their indices. Formally, you can print two indices *i* and *j* (the indices should be distinct). Then your program should read the response: the single integer equals to *a*_{i} + *a*_{j}.

It is easy to prove that it is always possible to guess the array using at most *n* requests.

Write a program that will guess the array *a* by making at most *n* requests.

Interaction

In each test your program should guess a single array.

The input starts with a line containing integer *n* (3 ≤ *n* ≤ 5000) — the length of the array. Your program should read it at first.

After that your program should print to the standard output the requests about the sum of two elements or inform that the array is guessed.

- In case your program is making a request to ask the sum of two elements, it should print line in the format "? i j" (
*i*and*j*are distinct integers between 1 and*n*), where*i*and*j*are indices in the array*a*. - In case your program informs that the array is guessed, it should print line in the format "!
*a*_{1}*a*_{2}...*a*_{n}" (it is guaranteed that all*a*_{i}are positive integers not exceeding 10^{5}), where*a*_{i}is the*i*-th element of the array*a*.

The response on a request is a single integer equal to *a*_{i} + *a*_{j}, printed on a separate line.

Your program can do at most *n* requests. Note that the final line «! *a*_{1} *a*_{2} ... *a*_{n}» is not counted as a request.

Do not forget about flush operation after each printed line.

After you program prints the guessed array, it should terminate normally.

Example

Input

5

9

7

9

11

6

Output

? 1 5

? 2 3

? 4 1

? 5 2

? 3 4

! 4 6 1 5 5

Note

The format of a test to make a hack is:

- The first line contains an integer number
*n*(3 ≤*n*≤ 5000) — the length of the array. - The second line contains
*n*numbers*a*_{1},*a*_{2}, ...,*a*_{n}(1 ≤*a*_{i}≤ 10^{5}) — the elements of the array to guess.

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Mar/19/2019 23:08:18 (d2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|