| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 1 초 | 2048 MB | 10 | 0 | 0 | 0.000% |
If all the parts of the ship of Theseus are replaced one by one over time, at what point − if any − does it stop being the same ship?
When he's not pondering deeply into the abstract, Theseus slays minotaurs in his spare time. This time however, he must first pass through a dark and twisted labyrinth. Since this is no easy feat, he asks the help of Ariadne to guide him. The labyrinth can be seen as a connected undirected graph with $n$ nodes (labelled from 1ドル$ to $n$) and $m$ edges, with a special node $t,ドル where the Minotaur sits.
Theseus cannot see the graph at all, but Ariadne can. She and Theseus will devise a strategy so that he can safely reach the node where the Minotaur is: she will put a label with either 0ドル$ or 1ドル$ on each of the m edges. After this, Theseus will enter the labyrinth through a node $s$ that Ariadne doesn't know beforehand.
Since it's very dark, at any moment in time he can only see the index of the node he's in, the indices of neighbouring nodes, and the labels of the adjacent edges. Also, because of the twisted nature of the labyrinth, he can never recall any information regarding previous nodes he has visited.
To reach the Minotaur safely, Theseus must move at most $min + C$ times, where $min$ is the minimum number of edges on the path from $s$ to $t,ドル and $C$ is a constant.
You will have to implement two functions:
std::vector<int> label(int n, std::vector<std::pair<int,int>> edges, int t);
int travel(int n, int u, std::vector<std::pair<int,int>> neighbours);
Attention! The program should not use global/static variables to communicate between different instances of label or travel. Any attempt to circumvent this would lead to undefined behaviour.
label.| 번호 | 배점 | 제한 |
|---|---|---|
| 1 | 4 | The graph is a clique (i.e. there is an edge between any two nodes 1ドル ≤ u < v ≤ n$). |
| 2 | 10 | The distance between the destination and any node in the graph is at most 2ドル$ edges. |
| 3 | 11 | The graph is a tree. |
| 4 | 13 | The graph is bipartite (i.e. there is a way to divide the nodes of the graph into two subsets such that there is no edge between two nodes from the same subset). |
| 5 | 12 | The graph will be a ladder (see definition below). |
| 6 | 50 | No additional constraints. |
Note: A ladder graph is a graph consisting of two parallel paths (or chains) of the same length, with each pair of corresponding nodes connected by an edge, forming the rungs of the ladder. Additionally, at one end of the ladder, there is a special node − the destination node $t$ − which is connected to both endpoints of the ladder, effectively acting as a common parent. It is guaranteed that $n$ will be odd for any such graph. See the image below.
Example 1
Consider we have a graph with 7 nodes and 7 edges (listed below). The start node will be 3 (marked with green) and the destination node is 7 (marked with red). The grader will first call:
label(7, {{1, 6}, {7, 6}, {2, 5}, {3, 2}, {3, 6}, {6, 5}, {6, 4}}, 7)
Let's assume the call to label returns {0, 1, 1, 1, 0, 1, 0}. Then the resulting graph will look like this:
What follows is a possible sequence of calls to travel that will lead to a correct solution:
| Call | Returned value |
|---|---|
travel(7, 3, {{2, 1}, {6, 0}}) |
2 |
travel(7, 2, {{5, 1}, {3, 1}}) |
5 |
travel(7, 5, {{6, 1}, {2, 1}}) |
6 |
travel(7, 6, {{3, 0}, {5, 1}, {1, 0}, {4, 0}, {7, 1}}) |
4 |
travel(7, 4, {{6, 0}}) |
6 |
travel(7, 6, {{3, 0}, {5, 1}, {1, 0}, {4, 0}, {7, 1}}) |
7 |
When the returned value is 7ドル$ (i.e. the destination), the program stops.
The sample grader reads the input in the following format:
First the grader will call label with the corresponding parameters and will label the edges of the graph according to the returned vector.
Then it will call travel with parameters $n,ドル $s$ and the neighbours of $s$. After the first call it will keep making successive calls to travel, with the current node being the one returned by the previous call, until the destination $t$ is reached.
In the end it will print the number of moves your solution made and the nodes it passed in order.
C++17, C++20, C++23, C++26, C++17 (Clang), C++20 (Clang)