Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <bits/stdc++.h>
- #define FASTER() ios_base::sync_with_stdio(false), cin.tie(NULL), cout.tie(NULL);
- #define ff first
- #define ss second
- #define pb push_back
- #define all(a) a.begin(), a.end()
- #define dbg(x) cerr<<" "<<#x<<" "<<x<<endl
- typedef long long ll;
- using namespace std;
- vector <vector <pair <int, int>>> gr;
- vector <bool> used;
- vector <int> first;
- void euler(int v) {
- while(first[v] < gr[v].size()) {
- auto p = gr[v][first[v]];
- first[v]++;
- int id = p.ff, to = p.ss;
- if(!used[id]) {
- used[id] = true;
- euler(to);
- cout << v << " " << to << "\n";
- }
- }
- }
- int main() {
- FASTER();
- int n, m;
- cin >> n >> m;
- gr.resize(n);
- first.resize(n, 0); //номер первого непосещенного ребра из вершины
- used.resize(m, false);
- for(int i = 0; i < m; i++) {
- int u, v;
- cin >> u >> v;
- u--; v--;
- gr[u].pb({i, v});
- gr[v].pb({i, u});
- }
- euler(0);
- }
Advertisement
Add Comment
Please, Sign In to add comment