Cod sursa(job #2559791)

Utilizator PatrascuAdrian1Patrascu Adrian Octavian PatrascuAdrian1 Data 27 februarie 2020 16:47:48
Problema Ciclu Eulerian Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.79 kb
#include <bits/stdc++.h>

using namespace std;

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

const int Nmax = 1e5 + 5;

vector <int> G[Nmax], ans;
int N,M;

void euler(int node)
{
    if(!G[node].empty())
    {
        int y = G[node].back();
        G[node].pop_back();
        for(vector<int>::iterator i = G[y].begin(); i != G[y].end(); ++i)
        {
            if(*i == node)
            {
                G[y].erase(i);
                break;
            }
        }
        euler(y);
    }
    ans.push_back(node);

}
int main()
{
    in >> N >> M;
    int x,y;
    while(M--)
    {
        in >> x >> y;
        G[x].push_back(y);
        G[y].push_back(x);
    }
    euler(1);
    for(auto i : ans)
        out << i << " ";
    return 0;
}