Cod sursa(job #2016221)

Utilizator adimiclaus15Miclaus Adrian Stefan adimiclaus15 Data 28 august 2017 22:22:28
Problema Ciclu Eulerian Scor 80
Compilator cpp Status done
Runda Arhiva educationala Marime 1.77 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <list>
using namespace std;
ifstream f("ciclueuler.in");
ofstream g("ciclueuler.out");
vector <int> a[100001],sol;
list <int> Q;
int n,m,grad[100001],viz[100001];
void euler(int x)
{
    vector <int>::iterator it;
    Q.push_back(x);
    while(!Q.empty())
    {
        x=Q.front();
        if(a[x].empty())
        {
            Q.pop_front();
            sol.push_back(x);
        }
        else
        {
            int i=a[x].back();
            Q.push_front(i);
            a[x].pop_back();
            for(it=a[i].begin();it!=a[i].end();it++)
            {
                if(*it==x)
                {
                    a[i].erase(it);
                    break;
                }
            }
        }
    }
}
void dfs(int x)
{
    int i;
    viz[x]=1;
    for(i=0;i<a[x].size();i++)
    {
        if(viz[a[x][i]]==0)
        {
            dfs(a[x][i]);
        }
    }
}
int main()
{
    int i,x,y,sw;
    f>>n>>m;
    for(i=1;i<=m;i++)
    {
        f>>x>>y;
        a[x].push_back(y);
        a[y].push_back(x);
        grad[x]++;
        grad[y]++;
    }
    sw=1;
    for(i=1;i<=n && sw==1;i++)
    {
        if(grad[i]%2==1)
        {
            sw=0;
        }
    }
    if(sw==0)
    {
        g<<-1<<" ";
    }
    else
    {
        sw=1;
        dfs(1);
        for(i=1;i<=n && sw==1;i++)
        {
            if(viz[i]==0)
            {
                sw=0;
            }
        }
        if(sw==0)
        {
            g<<-1<<" ";
        }
        else
        {
            euler(1);
            for(i=0;i<sol.size()-1;i++)
            {
                g<<sol[i]<<" ";
            }
        }
    }
    return 0;
}