Pagini recente » Cod sursa (job #1999307) | Cod sursa (job #2685068) | Cod sursa (job #1246514) | Cod sursa (job #563564) | Cod sursa (job #270056)
Cod sursa(job #270056)
#include <iostream.h>
#include <fstream.h>
#define nmax (100005)
#define nmax2 (500005)
ifstream fin("ciclueuler.in");
ofstream fout("ciclueuler.out");
int a[nmax][nmax],n,m,nr,c[nmax2];
void euler(int nod)
{int i;
for (i=1;i<=n;i++)
if (a[nod][i]!=0)
{a[nod][i]--;
a[i][nod]--;
euler(i);
}
nr++;
c[nr]=nod;
}
int main()
{int i,x,y;
fin>>n>>m;
for (i=1;i<=m;i++)
{fin>>x>>y;
a[x][y]+=1;
a[y][x]+=1;
}
euler(1);
if (nr<m || a[c[nr]][c[1]]) fout<<-1;
else
for (i=1;i<=m;i++)
fout<<c[i]<<" ";
fout.close();
return 0;
}