Pagini recente » Cod sursa (job #1065329) | Cod sursa (job #2915028) | Cod sursa (job #2821112) | Cod sursa (job #1385217) | Cod sursa (job #2082745)
#include<stdio.h>
#include<vector>
#include<stack>
using namespace std;
#define NMAX 100010
#define MMAX 500010
stack<int>s;
vector<pair<int,int> >l[NMAX];
int b[MMAX],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));
}
}
bool checkeu(){
int i;
for (i=1;i<=n;i++)
if (l[i].size()%2) {return false;}
return true;
}
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;
}