Pagini recente » Cod sursa (job #33562) | Cod sursa (job #2566520) | Cod sursa (job #2275717) | Cod sursa (job #2423808) | Cod sursa (job #2776007)
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("ciclueuler.in");
ofstream fout ("ciclueuler.out");
void usain_bolt()
{
ios::sync_with_stdio(false);
fin.tie(0);
}
const int N = 1e5 + 5;
list < int > a[N];
int d[N];
vector < int > sol;
stack < int > st;
int main()
{
usain_bolt();
int n, m;
fin >> n >> m;
for(int i = 1; i <= m; ++i) {
int x, y;
fin >> x >> y;
a[x].push_back(y);
a[y].push_back(x);
++d[x], ++d[y];
}
for(int i = 1; i <= n; ++i) {
if(d[i] % 2 == 1 || d[i] == 0) {
fout << -1;
return 0;
}
}
st.push(1);
while(!st.empty()) {
int v = st.top();
if((int) a[v].size() > 0) {
int x = *a[v].begin();
list < int > ::iterator it = find(a[x].begin(), a[x].end(), v);
if(it != a[x].end()) {
a[x].erase(it);
a[v].erase(a[v].begin());
}
st.push(x);
}
else {
sol.push_back(v);
st.pop();
}
}
sol.pop_back();
for(auto v : sol) {
fout << v << " ";
}
return 0;
}