Cod sursa(job #2698612)

Utilizator AnastasiaStefanescuAnastasia Stefanescu AnastasiaStefanescu Data 22 ianuarie 2021 16:23:32
Problema Ciclu Eulerian Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.05 kb
#include <fstream>
#include <iostream>
#include <queue>
#include <set>
#include <vector>

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

int f[100001], a[100001], b[100001], n, m;

vector <int> mc[500001];
vector <int> sol;

void euler(int nod)
{
    int nod2, muchie;
    
    while (mc[nod].size() != 0)
    {
        muchie = mc[nod].back();
        mc[nod].pop_back();
        
        if(f[muchie] == 0)
        {
            f[muchie] = 1;
        
        if(a[muchie] == nod)
            nod2 = b[muchie];
        else
            nod2 = a[muchie];
        euler(nod2);
        }
    }
    sol.push_back(nod);
}

int main()
{
    int i;
    fin >> n >> m;
    for (i = 1; i<= m; i++)
    {
        cin >> a[i] >> b[i];
        mc[a[i]].push_back(i);
        mc[b[i]].push_back(i);
    }
    
    for (i = 1; i<= n; i++)
        if(mc[i].size() % 2 == 1)
        {
            fout << "-1";
            return 0;
        }
    
    euler(1);
    
    for (i = 0; i< sol.size()-1; i++)
        fout << sol[i] << " ";
    
}