-
Notifications
You must be signed in to change notification settings - Fork 1
/
6.Round_Trip.cpp
78 lines (71 loc) · 1.73 KB
/
6.Round_Trip.cpp
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
76
77
78
// Video link to understand the algorithm https://www.youtube.com/watch?v=n_t0a_8H8VY
// We have to find cycle in an undirected graph.
#include <bits/stdc++.h>
using namespace std;
#define P pair<int,int>
#define int64 int64_t
#define IOS ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define ll long long
#define pb push_back
#define str string
#define ri(x) int x;cin>>x;
#define rl(x) ll x; cin>>x;
#define rs(x) str x; cin>>x;
#define rd(x) d x; cin>>x;
#define w(x) cout<<x;
#define vec(x) std::vector<x>
#define nl '\n'
#define all(x) x.begin(),x.end()
#define map_traverse(it,x) for(auto it = BN(x); it!= ED(x); it++)
#define debug(x) for(auto y : x) {cout<<y<<" ";} cout<<nl;
#define PI 3.14159265358979323846264338327950L
#define rep(i,a,b) for(int i=a;i<b;i++)
#define per(i,n) for(int i=n-1;i>=0;i--)
const unsigned int M = 1000000007;
const int mxN=2e5;
const int N = 100031;
bool bad = false;
std::vector<int>a[N],par(N,0),vis(N,0);
void dfs(int u,int pu){
par[u] = pu;
vis[u]=1;
for(auto x: a[u]){
if(x==pu)continue;
if(vis[x]){
vector<int>ans;
ans.pb(u);
int temp = u;
while(par[temp]!=x){
temp = par[temp];
ans.pb(temp);
}
ans.pb(x);
ans.pb(u);
cout<<ans.size()<<nl;
for(auto x:ans){
cout<<x<<" ";
}
exit(0);
}else{
dfs(x,u);
}
}
}
void solve(){
int n,m;
cin>>n>>m;
rep(i,0,m){
int x,y; cin>>x>>y;
a[x].pb(y); a[y].pb(x);
}
rep(i,1,n+1){
if(!vis[i]){
dfs(i,-1);
}
}
cout<<"IMPOSSIBLE";
}
int main(){
IOS;
solve();
}