CF1879E.Interactive Game with Coloring
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
This is an interactive problem. Remember to flush your output while communicating with the testing program. You may use fflush(stdout) in C++, system.out.flush() in Java, stdout.flush() in Python or flush(output) in Pascal to flush the output. If you use some other programming language, consult its documentation. You may also refer to the guide on interactive problems: https://codeforces.com/blog/entry/45307.
You are given a tree on n vertices; vertex 1 is the root of the tree. For every i∈[2,n] , the parent of the i -th vertex is pi , and pi<i .
You have to color all edges of the tree using the minimum possible number of colors such that you can win the game on that tree (every edge should be painted into exactly one color).
The game we're going to play will be conducted as follows. After you paint the edges and print their colors, the jury will place a chip into one of the vertices of the tree (except for the root). Your goal is to move this chip to the root in exactly d moves, where d is the distance from the root to that vertex (the distance is equal to the number of edges on the path). If the chip reaches the root in d moves, you win. Otherwise, you lose.
The jury won't tell you where the chip is located. You won't even know the value of d in advance. However, at the start of each move, you will be told how many edges of each color are incident to the current vertex (this includes both the edge leading up the tree and the edges leading away from the root). You have to choose one of these colors, and the chip will be moved along the edge of the chosen color (if there are multiple edges with that color incident to the current vertex, the jury gets to choose one of them). After the chip is moved, you will be told the same information about the current vertex again, and the game continues, until you either reach the root, or you make d moves without reaching the root.
The interactor for this problem is adaptive. It means that both the starting vertex and the current vertex are not fixed and may change "on the run" depending on the output of your program. However, the state of the game will always be consistent with the information you are given: there will always be at least one starting vertex and at least one path of your chip from that vertex consistent with both the information about the colors you receive and the colors you've chosen during the moves.
输入格式
The first line contains one integer n ( 3≤n≤100 ) — the number of vertices in the tree.
The second line contains n−1 integers p2,p3,…,pn ( 1≤pi<i ), where pi is the parent of the i -th vertex in the tree.
输出格式
First, you have to print the coloring of the edges you've chosen as follows:
- in the first line, print one integer k ( 1≤k≤n−1 ) — the number of colors you are using;
- in the second line, print n−1 integers c2,c3,…,cn ( 1≤ci≤k ), where ci should be the color of the edge connecting pi with i .
Then, the game begins. At the start of each move, the jury program prints one of the following:
- one integer 1 on a separate line, indicating that the chip has reached the root and you won;
- one integer −1 on a separate line, indicating that either you didn't reach the root in d moves and lost, or you have done something incorrect (either the coloring you provided didn't meet the constraints, or your previous move is impossible);
- or one integer 0 on a separate line, followed by a line containing k integers e1,e2,…,ek , where ei is the number of edges with color i incident to the current vertex.
If you receive 1 or −1 , your program should terminate immediately, otherwise the verdict for your submission may be undefined. If you receive 0 followed by k integers e1,e2,…,ek , you have to print one integer indicating the color you choose during the move (of course, ei for that color should not be equal to 0 ).
Don't forget to flush the output every time you print something!
输入输出样例
输入#1
5 1 1 1 1 0 1 1
输出#1
1 1 1 1 1 1
输入#2
4 1 2 3 0 0 1 0 0 1 1 0 0 1 0 1 1
输出#2
3 3 1 2 2 1 3
输入#3
3 1 2 0 1 1 1
输出#3
2 1 2 1
说明/提示
In the first example, every vertex from 2 to n is connected to the root. So, we can paint all edges into the same color 1 , and when the game starts, there will be only one edge incident to the current vertex (and it will lead to the root).
In the second example, the tree is a path of 4 vertices. We have to paint its edges into different colors, because it can be shown that we don't have a winning strategy with just two colors.