Codeforces celebrates 10 years! We are pleased to announce the crowdfunding-campaign. Congratulate us by the link https://codeforces.com/10years.
×

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only 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

F. Lost Root

time limit per test

3 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputThe graph is called tree if it is connected and has no cycles. Suppose the tree is rooted at some vertex. Then tree is called to be perfect $$$k$$$-ary tree if each vertex is either a leaf (has no children) or has exactly $$$k$$$ children. Also, in perfect $$$k$$$-ary tree all leafs must have same depth.

For example, the picture below illustrates perfect binary tree with $$$15$$$ vertices:

There is a perfect $$$k$$$-ary tree with $$$n$$$ nodes. The nodes are labeled with distinct integers from $$$1$$$ to $$$n$$$, however you don't know how nodes are labelled. Still, you want to find the label of the root of the tree.

You are allowed to make at most $$$60 \cdot n$$$ queries of the following type:

- "? $$$a$$$ $$$b$$$ $$$c$$$", the query returns "Yes" if node with label $$$b$$$ lies on the path from $$$a$$$ to $$$c$$$ and "No" otherwise.

Both $$$a$$$ and $$$c$$$ are considered to be lying on the path from $$$a$$$ to $$$c$$$.

When you are ready to report the root of the tree, print

- "! $$$s$$$", where $$$s$$$ is the label of the root of the tree.

It is possible to report the root only once and this query is not counted towards limit of $$$60 \cdot n$$$ queries.

Interaction

The first line of the standard input stream contains two integers $$$n$$$ and $$$k$$$ ($$$3 \le n \le 1500$$$, $$$2 \le k < n$$$) — the number of nodes in the tree and the value of $$$k$$$.

It is guaranteed that $$$n$$$ is such that the tree forms a perfect $$$k$$$-ary tree.

You can ask at most $$$60 \cdot n$$$ queries. To ask a query, print a line of form "? $$$a$$$ $$$b$$$ $$$c$$$", where $$$1 \le a, b, c \le n$$$. After that you should read a single line containing "Yes" or "No" depending on the answer of the query.

The tree is fixed for each test and it doesn't depend on your queries.

When you are ready to print the answer, print a line of the form "! $$$s$$$", where $$$s$$$ is the label of the root vertex and then terminate your program.

After printing each query do not forget to print end of line and flush the output. Otherwise you may get Idleness limit exceeded. To do this, use:

- fflush(stdout) or cout.flush() in C++;
- System.out.flush() in Java;
- flush(output) in Pascal;
- stdout.flush() in Python;
- See documentation for other languages.

In case your program will make more than $$$60 \cdot n$$$ queries, but in other aspects would follow the interaction protocol and terminate coorectly, it will get verdict «Wrong Answer».

Hacks

To hack the solution use the following test format:

The first line should contain integers $$$n$$$ and $$$k$$$ ($$$3 \le n \le 1500$$$, $$$2 \le k \le 1500$$$) — the number of vertices and the $$$k$$$ parameter of the tree.

Of course, the value of $$$n$$$ must correspond to the size of the valid $$$k$$$-ary tree of some depth.

The second line should contain $$$a_1, a_2, \ldots, a_n$$$ ($$$1 \le a_i \le n$$$) — the labels of the tree in the natural order, all labels must be distinct.

Let's call the following ordering of the tree vertices to be natural: first the root of the tree goes, then go all vertices on depth of one edge from root, ordered from left to right, then go all vertices on depth of two edges from root, ordered from left to right, and so on until the maximum depth.

This way, the $$$a_1$$$ is the answer for the hack.

Example

Input

3 2

No

Yes

Output

? 1 3 2

? 1 2 3

! 2

Note

The tree in the example is as follows:

The input and output for example illustrate possible interaction on that test (empty lines are inserted only for clarity).

The hack corresponding to the example would look like:

3 2

2 3 1

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Feb/19/2020 05:23:48 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|