Pagini recente » Cod sursa (job #900994) | Cod sursa (job #869277) | Cod sursa (job #2892070) | Cod sursa (job #3148606) | Cod sursa (job #2082726)
#include<stdio.h>
#include<list>
#include<stack>
using namespace std;
stack<int>s;
list<pair<int,int> >l[100010];
int b[500010],n,m;
void read(){
int i,x,y;
scanf("%d%d",&n,&m);
for (i=1;i<=m;i++){
scanf("%d%d",&x,&y);
l[x].push_back(make_pair(y,i));
l[y].push_back(make_pair(x,i));
}
}
int checkeu(){
int i;
for (i=1;i<=n;i++)
if (l[i].size()%2) {return 0;}
return 1;
}
void euler(){
int i,j,k;
s.push(1);
while (!s.empty()){
i=s.top();
if (!l[i].empty()){
j=l[i].back().first;
k=l[i].back().second;
l[i].pop_back();
if (!b[k]){
b[k]=1;
s.push(j);
}
}
else{
s.pop();
printf("%d ",i);
}
}
}
int main()
{
freopen("ciclueuler.in", "r", stdin);
freopen("ciclueuler.out", "w", stdout);
read();
if (checkeu()) euler();
else printf("-1");
return 0;
}