Pagini recente » Cod sursa (job #2221980) | Cod sursa (job #693915) | Cod sursa (job #2322000) | Cod sursa (job #597518) | Cod sursa (job #1588550)
#include<fstream>
#include<vector>
#include<deque>
using namespace std;
ifstream f("ciclueuler.in");
ofstream g("ciclueuler.out");
int n,m,x1,x2,x,y,i,nod;
int grad[100005];
bool viz[500005];
vector<int>v[100001],muc[100001];
deque<int>q;
int main()
{
f>>n>>m;
for(i=1;i<=m;i++)
{
f>>x>>y;
v[x].push_back(y);
v[y].push_back(x);
muc[x].push_back(i);
muc[y].push_back(i);
grad[x]++;
grad[y]++;
}
for(i=1;i<=n;i++)
if(grad[i]%2==1)
{
g<<-1;
return 0;
}
q.push_back(1);
while(!q.empty())
{
nod=q.back();
if(grad[nod]==0)
{
g<<nod<<" ";
q.pop_back();
}
else
{
x1=v[nod].back();
x2=muc[nod].back();
v[nod].pop_back();
muc[nod].pop_back();
if(viz[x2]==0)
{
viz[x2]=1;
q.push_back(x1);
grad[x1]--;
grad[nod]--;
}
}
}
return 0;
}