Cod sursa(job #1916379)

Utilizator tudorgalatanRoman Tudor tudorgalatan Data 9 martie 2017 09:17:50
Problema Ciclu Eulerian Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.04 kb
#include <fstream>
#include <vector>

using namespace std;

ifstream fin ("ciclueuler.in");
ofstream fout ("ciclueuler.out");

inline void DFS (unsigned int node);

unsigned int N, M;
unsigned int u[500001], v[500001];

vector <unsigned int> G[100001];
unsigned int pos[100001];
bool seen[500001];
unsigned int i, k;

unsigned int sol[500001];

int main ()
{
    fin >> N >> M;
    for (i=1; i<=M; i++)
    {
        fin >> u[i] >> v[i];
        G[u[i]].push_back(i);
        G[v[i]].push_back(i);
    }
    for (i=1; i<=N; i++)
        if (G[i].size()%2 == 1)
        {
            fout << -1 << '\n';
            return 0;
        }
    DFS(1);
    for (i=1; i<=k-1; i++)
        fout << sol[i] << ' ';
    return 0;
}

inline void DFS (unsigned int node)
{
    unsigned int K;
    while (pos[node] < G[node].size())
    {
        K = G[node][pos[node]];
        pos[node]++;
        if (!seen[K])
        {
            seen[K] = 1;
            DFS(u[K]+v[K]-node);
        }
    }
    sol[++k] = node;
}