codeforces#P1494F. Delete The Edges

    ID: 31874 远端评测题 8000ms 512MiB 尝试: 0 已通过: 0 难度: 10 上传者: 标签>brute forceconstructive algorithmsdfs and similargraphsimplementation*2900

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