306043: CF1137D. Cooperative Game
Memory Limit:512 MB
Time Limit:1 S
Judge Style:Text Compare
Creator:
Submit:0
Solved:0
Description
Cooperative Game
题意翻译
- 这是一道交互题。 - 一个有向图,由一条边数为 $t$ 的链和一个长度为 $c$ 的环组成,每个点有且仅有一条出边,如图。你不知道 $t$ 和 $c$ 的值。 - 在链的开头(图中房子处)有 $10$ 枚棋子。你每次可以选定一些棋子,把这些棋子向它们所在点的出边移动一步。移动之后,你会得到所有 $10$ 枚棋子中,哪些棋子处于同一个点上,哪些棋子不在同一个点上。 - 你需要在 $3(t+c)$ 次操作之后,把所有 $10$ 枚棋子移动到链和环的交点处(图中的旗子处)题目描述
This is an interactive problem. Misha likes to play cooperative games with incomplete information. Today he suggested ten his friends to play a cooperative game "Lake". Misha has already come up with a field for the upcoming game. The field for this game is a directed graph consisting of two parts. The first part is a road along the coast of the lake which is a cycle of $ c $ vertices. The second part is a path from home to the lake which is a chain of $ t $ vertices, and there is an edge from the last vertex of this chain to the vertex of the road along the coast which has the most beautiful view of the lake, also known as the finish vertex. Misha decided to keep the field secret, so nobody knows neither $ t $ nor $ c $ . ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1137D/34a9ab7816c73b7f2368756224775ddf156360e3.png)Note that each vertex of the field has exactly one outgoing edge and all the vertices except the home vertex and the finish vertex have exactly one ingoing edge. The home vertex has no incoming edges, the finish vertex has two incoming edges. At the beginning of the game pieces of all the ten players, indexed with consecutive integers from $ 0 $ to $ 9 $ , are at the home vertex. After that on each turn some of the players can ask Misha to simultaneously move their pieces along the corresponding edges. Misha will not answer more than $ q $ such queries. After each move Misha will tell players whose pieces are at the same vertices and whose pieces are at different vertices. The goal of the game is to move all the pieces to the finish vertex. Misha's friends have no idea how to win in such a game without knowledge of $ c $ , $ t $ and $ q $ , but luckily they are your friends. Help them: coordinate their actions to win the game. Misha has drawn such a field that $ 1 \le t, c $ , $ (t+c) \leq 1000 $ and $ q = 3 \cdot (t+c) $ .输入输出格式
输入格式
There is no input — go to the interaction part straight away.
输出格式
After all friends gather at the finish vertex, print "done" and terminate your program. Interaction To give a command to move the friends, print "next" and then space-separated indices of the friends you want to move. For example, to give the command to move the friends with indices $ 0 $ , $ 2 $ , $ 5 $ and $ 9 $ print "next 0 2 5 9". At each turn, you must move at least one of your friends. As an answer, first read an integer $ k $ , and then $ 10 $ digits divided into $ k $ space-separated groups. The friends that correspond to the indices in the same group are in the same vertex. The friends that correspond to indices in different groups are in different vertices. The indices in each group follow in ascending order. For example, the answer "2 05 12346789" means that the friends with indices $ 0 $ and $ 5 $ are in one vertex, and all other friends are in the same but different vertex. The answer "4 01 567 234 89" means that Misha's friends are in four different vertices: the friends with indices $ 0 $ and $ 1 $ are in the first, the friends with indices $ 5 $ , $ 6 $ and $ 7 $ are in the second, the friends with indices $ 2 $ , $ 3 $ and $ 4 $ are in the third, and the friends with indices $ 8 $ and $ 9 $ are in the fourth. After printing a query do not forget to output end of line and flush the output. Otherwise you will 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. Answer "stop" instead of a valid one means that you made an invalid query. Exit immediately after receiving "stop" and you will see Wrong answer verdict. Otherwise you can get an arbitrary verdict because your solution will continue to read from a closed stream. Hacks In order to hack, print two integers $ t $ and $ c $ in a single line ( $ 1 \le t, c $ , $ (t+c) \leq 1000 $ ).
输入输出样例
输入样例 #1
2 05 12346789
3 246789 135 0
3 246789 0 135
3 246789 0 135
2 135 0246789
1 0123456789
输出样例 #1
next 0 5
next 0 1 3
next 2 3 0 1 4 5 6 7 8 9
next 9 8 7 6 5 4 3 2 1 0
next 0 1 3 5
next 1 3 5
done