VK Cup 2017 - Round 2 |
---|

Finished |

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.

binary search

divide and conquer

interactive

trees

*3200

No tag edit access

The problem statement has recently been changed. View the changes.

×
E. Verifying Kingdom

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputThis is an interactive problem.

The judge has a hidden rooted full binary tree with *n* leaves. A full binary tree is one where every node has either 0 or 2 children. The nodes with 0 children are called the leaves of the tree. Since this is a full binary tree, there are exactly 2*n* - 1 nodes in the tree. The leaves of the judge's tree has labels from 1 to *n*. You would like to reconstruct a tree that is isomorphic to the judge's tree. To do this, you can ask some questions.

A question consists of printing the label of three distinct leaves *a*_{1}, *a*_{2}, *a*_{3}. Let the depth of a node be the shortest distance from the node to the root of the tree. Let *LCA*(*a*, *b*) denote the node with maximum depth that is a common ancestor of the nodes *a* and *b*.

Consider *X* = *LCA*(*a*_{1}, *a*_{2}), *Y* = *LCA*(*a*_{2}, *a*_{3}), *Z* = *LCA*(*a*_{3}, *a*_{1}). The judge will tell you which one of *X*, *Y*, *Z* has the maximum depth. Note, this pair is uniquely determined since the tree is a binary tree; there can't be any ties.

More specifically, if *X* (or *Y*, *Z* respectively) maximizes the depth, the judge will respond with the string "X" (or "Y", "Z" respectively).

You may only ask at most 10·*n* questions.

Input

The first line of input will contain a single integer *n* (3 ≤ *n* ≤ 1 000) — the number of leaves in the tree.

Output

To print the final answer, print out the string "-1" on its own line. Then, the next line should contain 2*n* - 1 integers. The *i*-th integer should be the parent of the *i*-th node, or -1, if it is the root.

Your answer will be judged correct if your output is isomorphic to the judge's tree. In particular, the labels of the leaves do not need to be labeled from 1 to *n*. Here, isomorphic means that there exists a permutation π such that node *i* is the parent of node *j* in the judge tree if and only node π(*i*) is the parent of node π(*j*) in your tree.

Interaction

To ask a question, print out three distinct integers *a*_{1}, *a*_{2}, *a*_{3}. These integers should be between 1 and *n*, inclusive.

The judge will respond with a single character, either "X", "Y", "Z".

If the string is "X" (or "Y", "Z" respectively), that means the pair (*a*_{1}, *a*_{2}) (or (*a*_{2}, *a*_{3}), (*a*_{3}, *a*_{1}) respectively) has the deepest *LCA* among the three pairs.

You may only ask a question at most 10·*n* times, otherwise, you will get Wrong Answer.

When you are ready to answer, print out a single integer "-1" on its own line. The next line should contain 2*n* - 1 integers. The *i*-th integer should be the parent of the *i*-th node, or -1, if it is the root. Do not forget to flush the final answer as well. Printing the answer does not count as asking a question.

You will get Wrong Answer verdict if

- Your question or answers are not in the format described in this statement.
- You ask strictly more than 10·
*n*questions. - Your question contains duplicate indices.
- Your final answer is not isomorphic to the judge tree.

You will get Idleness Limit Exceeded if you don't print anything or if you forget to flush the output, including for the final answer (more info about flushing output below).

To flush you can use (just after printing an integer and end-of-line):

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

If at any moment your program reads -1 as an answer, it should immediately exit normally (for example, by calling exit(0)). You will get Wrong Answer in this case, it means that you made more queries than allowed, or made an invalid query. If you ignore this, you can get other verdicts since your program will continue to read from a closed stream.

Hacking To hack someone, use the following format

n

p_1 p_2 ... p_{2n-1}

This denotes a tree where the parent of the *i*-th node is *p*_{i} (*p*_{i} = - 1 or *n* < *p*_{i} ≤ 2*n* - 1). If *p*_{i} is equal to -1, then node *i* is the root. This input must describe a valid full rooted binary tree.

Of course, contestant programs will not be able to see this input.

Example

Input

5

X

Z

Y

Y

X

Output

1 4 2

1 2 4

2 4 1

2 3 5

2 4 3

-1

-1 1 1 2 2 3 3 6 6

Note

For the first sample, the judge has the hidden tree:

Here is a more readable format of the interaction:

Codeforces (c) Copyright 2010-2023 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: May/30/2023 03:08:57 (k2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|