Pagini recente » Cod sursa (job #473882) | Cod sursa (job #870170) | Cod sursa (job #1063540) | Cod sursa (job #3130703) | Cod sursa (job #1829926)
#include <iostream>
#include<fstream>
#include<vector>
using namespace std;
ifstream f("ciclueuler.in");
ofstream g("ciclueuler.out");
vector<int>v[100011];
long long n,m,i,x,y;
void sterge(int x,int y)
{
bool ok=1;
for(int k=0;k<v[x].size()&&ok;k++)
if(v[x][k]==y)
{
ok=0;
swap(v[x][k],v[x][v[x].size()-1]);
v[x].pop_back();
}
}
void euler(int nod)
{
while(v[nod].size())
{
int vec=v[nod][0];
sterge(nod,vec);
sterge(vec,nod);
euler(vec);
}
g<<nod<<' ';
}
int main()
{
f>>n>>m;
for(i=1;i<=m;i++)
{
f>>x>>y;
v[x].push_back(y);
v[y].push_back(x);
}
bool ok=1;
for(i=1;i<=n && ok;i++)
if(v[i].size()%2)
ok=0;
if(ok)
euler(1);
else g<<-1;
}