Cod sursa(job #1829926)

Utilizator GeanaVladGeana Vlad GeanaVlad Data 15 decembrie 2016 20:47:13
Problema Ciclu Eulerian Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.84 kb
#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;
}