1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
| #include <bits/stdc++.h>
#define AC \
ios::sync_with_stdio(0); \
cin.tie(0); \
cout.tie(0);
using namespace std;
#define DEBUG
void dfs(int id, vector<vector<int>> &adj, vector<bool> &vis, vector<int> &path, int parent)
{
vis[id] = true;
path.push_back(id);
for (int nei : adj[id])
{
if (nei == parent)
{
continue;
}
if (vis[nei])
{
path.push_back(nei);
int sz = path.size(), pos = -1;
for (int i = 0; i < sz - 1; i++)
{
if (path[i] == nei)
{
pos = i;
break;
}
}
cout << sz - pos << "\n";
for (int i = pos; i < sz; i++)
{
cout << path[i] << " ";
}
exit(0);
}
dfs(nei, adj, vis, path, id);
}
path.pop_back();
}
int main()
{
AC;
int n, m;
cin >> n >> m;
vector<vector<int>> adj(n + 1, vector<int>());
vector<bool> vis(n + 1, 0);
for (int i = 0; i < m; i++)
{
int s, e;
cin >> s >> e;
adj[s].push_back(e);
adj[e].push_back(s);
}
for (int i = 1; i <= n; i++)
{
if (!vis[i])
{
vector<int> path;
dfs(i, adj, vis, path, 0);
}
}
cout << "IMPOSSIBLE\n";
return 0;
}
|