codeforces#P1494F. Delete The Edges
Delete The Edges
Description
You are given an undirected connected graph consisting of $n$ vertices and $m$ edges. Your goal is to destroy all edges of the given graph.
You may choose any vertex as the starting one and begin walking from it along the edges. When you walk along an edge, you destroy it. Obviously, you cannot walk along an edge if it is destroyed.
You can perform the mode shift operation at most once during your walk, and this operation can only be performed when you are at some vertex (you cannot perform it while traversing an edge). After the mode shift, the edges you go through are deleted in the following way: the first edge after the mode shift is not destroyed, the second one is destroyed, the third one is not destroyed, the fourth one is destroyed, and so on. You cannot switch back to the original mode, and you don't have to perform this operation if you don't want to.
Can you destroy all the edges of the given graph?
The first line contains two integers $n$ and $m$ ($2 \le n \le 3000$; $n - 1 \le m \le \min(\frac{n(n-1)}{2}, 3000$)) — the numbef of vertices and the number of edges in the graph.
Then $m$ lines follow, each containing two integers $x_i$ and $y_i$ ($1 \le x_i, y_i \le n$; $x_i \ne y_i$) — the endpoints of the $i$-th edge.
These edges form a connected undirected graph without multiple edges.
If it's impossible to destroy all of the edges, print 0.
Otherwise, print the sequence of your actions as follows. First, print $k$ — the number of actions ($k \le 2m + 2$). Then, print the sequence itself, consisting of $k$ integers. The first integer should be the index of the starting vertex. Then, each of the next integers should be either the index of the next vertex in your traversal, or $-1$ if you use mode shift. You are allowed to use mode shift at most once.
If there are multiple answers, print any of them.
Input
The first line contains two integers $n$ and $m$ ($2 \le n \le 3000$; $n - 1 \le m \le \min(\frac{n(n-1)}{2}, 3000$)) — the numbef of vertices and the number of edges in the graph.
Then $m$ lines follow, each containing two integers $x_i$ and $y_i$ ($1 \le x_i, y_i \le n$; $x_i \ne y_i$) — the endpoints of the $i$-th edge.
These edges form a connected undirected graph without multiple edges.
Output
If it's impossible to destroy all of the edges, print 0.
Otherwise, print the sequence of your actions as follows. First, print $k$ — the number of actions ($k \le 2m + 2$). Then, print the sequence itself, consisting of $k$ integers. The first integer should be the index of the starting vertex. Then, each of the next integers should be either the index of the next vertex in your traversal, or $-1$ if you use mode shift. You are allowed to use mode shift at most once.
If there are multiple answers, print any of them.
Samples
3 3
1 2
2 3
3 1
4
1 2 3 1
4 3
1 2
2 3
4 2
8
2 -1 1 2 3 2 4 2
5 5
1 2
2 3
3 1
2 4
2 5
9
2 3 1 2 -1 4 2 5 2
5 5
1 2
2 3
3 1
2 4
4 5
8
5 4 2 3 1 -1 2 1
6 5
1 2
2 3
3 4
4 5
3 6
0