Please subscribe to the official Codeforces channel in Telegram via the link: https://t.me/codeforces_official.
×

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

B. Minimum and Maximum

time limit per test

4 secondsmemory limit per test

512 megabytesinput

standard inputoutput

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

In this problem, you need to find maximal and minimal elements of an array. What could be simpler?

You can imagine that the jury has an array, and initially you know the only number *n* — array's length.

Array's elements are numbered from 1 to *n*. You are allowed to compare two elements of the array by using their indices *i* and *j*. There are three possible responses to this query: '<' (if *a*_{i} is less than *a*_{j}), '=' (if *a*_{i} is equal to *a*_{j}) and finally '>' (if *a*_{i} is greater than *a*_{j}).

It's known that it's always possible to find both maximal and minimal elements of the array by using no more than comparisons, where ⌈ *x*⌉ is the result of rounding *x* up.

Write the program that will find positions of the minimum and the maximum in the jury's array of length *n*, by using no more than *f*(*n*) comparisons.

Interaction

Each test for this problem will contain one or more arrays. You have to find positions of minimal and maximal elements for each of these arrays. The first line of the input contains integer *T* (1 ≤ *T* ≤ 1000) — number of arrays in the test.

Thus, at the beginning, you program should read number *T*, and then it should solve the problem for *T* jury's arrays one by one.

Then input for each array goes. Firstly, your program has to read the number *n* (1 ≤ *n* ≤ 50) — the length of the array. It will be provided in the next line of the input.

Further, your program can perform comparisons or report that the answer is found.

- To perform a comparison, you have to output string of the following pattern «? i j» (
*i*and*j*must be integer numbers from 1 to*n*) — the indices of the elements to compare in the current query. - To report the indices of minimal and maximal elements of the hidden array, your program have to output a line in the form «! i j» (
*i*and*j*must be integer numbers from 1 to*n*), where*i*is an index of the minimal element of array, and*j*is an index of the maximal element of the array. If there are several possible answers to the problem, you can output any of them.

There are several possible responses for a comparison:

- '<' — if
*a*_{i}is less than*a*_{j}, - '=' — if
*a*_{i}is equal to*a*_{j}, - '>' — if
*a*_{i}is greater than*a*_{j}.

For an array of length *n* your program can make at most comparisons. Note that the operation of reporting an answer («! i j» ) is not included into the value of *f*(*n*).

After the answer is reported, your program has to solve the problem for the next array or it should terminate if all *T* arrays are processed.

Example

Input

2

2

>

3

=

=

Output

? 1 2

! 2 1

? 3 1

? 2 1

! 2 3

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/14/2018 19:03:51 (d1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|