Pagini recente » Cod sursa (job #2739466) | Cod sursa (job #1511278) | Istoria paginii runda/ms98/clasament | Istoria paginii utilizator/militaru.adrian | Cod sursa (job #1277486)
#include <bits/stdc++.h>
#define N 100010
#define pb push_back
using namespace std;
ifstream fin("ciclueuler.in");
ofstream fout("ciclueuler.out");
int viz[N],n,m,i,x,y;
vector<int>v[N],st;
void df(int nod)
{
viz[nod]=1;
for(auto vec:v[nod])
if(!viz[vec])
df(vec);
}
int main()
{
fin>>n>>m;
for(;m;m--)
{
fin>>x>>y;
v[x].pb(y);
v[y].pb(x);
}
for(i=1;i<=n;i++)
if(v[i].size()&1)
{
cout<<-1;
return 0;
}
df(1);
for(i=1;i<=n;i++)
if(!viz[i])
{
cout<<-1;
return 0;
}
st.pb(1);
while(st.size())
{
x=st.back();
if(v[x].size())
{
y=v[x].back();
v[x].pop_back();
for(auto vec:v[y])
if(vec==x)
{
vec=v[y].back();
v[y].pop_back();
break;
}
st.pb(y);
}
else
{
fout<<st.back()<<' ';
st.pop_back();
}
}
return 0;
}