Cod sursa(job #2838822)

Utilizator AnastasiaStefanescuAnastasia Stefanescu AnastasiaStefanescu Data 24 ianuarie 2022 18:10:26
Problema Ciclu Eulerian Scor 50
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++)
    {
        fin >> 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(); i++)
        fout << sol[i] << " ";
    
}