Cod sursa(job #3302332)

Utilizator Barbu_MateiBarbu Matei Barbu_Matei Data 6 iulie 2025 15:00:26
Problema Ciclu Eulerian Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.91 kb
#include <bits/stdc++.h>
using namespace std;

int n, m;
vector<int> v[100001];
unordered_map<int, int> mt[100001];
stack<int> ans;

void dfs(int node) {
    for (int i = 0; i < v[node].size(); ++i) {
        if (mt[node][v[node][i]]) {
            --mt[node][v[node][i]];
            --mt[v[node][i]][node];
            dfs(v[node][i]);
        }
    }
    ans.push(node);
}

int main() {
    ifstream cin("ciclueuler.in");
    ofstream cout("ciclueuler.out");
    cin >> n >> m;
    for (int i = 1; i <= m; ++i) {
        int x, y;
        cin >> x >> y;
        v[x].push_back(y);
        v[y].push_back(x);
        ++mt[x][y];
        ++mt[y][x];
    }
    for (int i = 1; i <= n; ++i) {
        if (v[i].size() % 2 != 0) {
            cout << -1;
            return 0;
        }
    }
    dfs(1);
    while (ans.size() != 1) {
        cout << ans.top() << " ";
        ans.pop();
    }
}