Submission #1081652

#TimeUsernameProblemLanguageResultExecution timeMemory
1081652EliasPipes (CEOI15_pipes)C++17
0 / 100
5080 ms10836 KiB
#include <bits/stdc++.h> using namespace std; int parent[100000]; int depth[100000]; int root[100000]; int union_parent[100000]; vector<vector<int>> children; int find(int a) { if (union_parent[a] == a) return a; return union_parent[a] = find(union_parent[a]); } bool unite(int a, int b) { a = find(a); b = find(b); if (a == b) return false; // if (rand() % 2) // swap(a, b); union_parent[a] = b; return true; } vector<vector<int>> adj; int iter = 0; void dfs_reconstruct(int i, int d, int p, int r) { root[i] = r; parent[i] = p; depth[i] = d; assert(depth[i] > depth[parent[i]]); iter++; assert(iter < 10000); for (int c : adj[i]) { if (c == p) continue; dfs_reconstruct(c, d + 1, i, r); } } signed main() { cin.tie(0); ios_base::sync_with_stdio(false); int n, m; cin >> n >> m; children.resize(n); adj.resize(n); for (int i = 0; i < n; i++) { parent[i] = root[i] = union_parent[i] = i; children[i] = vector<int>{i}; depth[i] = 1; } while (m--) { int a, b; cin >> a >> b; a--, b--; a = find(a); b = find(b); if (root[a] == root[b]) { while (a != b) { assert(root[a] == root[b]); if (depth[a] < depth[b]) swap(a, b); // assert(unite(a, parent[a])); a = find(a); b = find(b); } } else { if (children[root[a]].size() < children[root[b]].size()) swap(a, b); vector<pair<int, int>> inserts; vector<int> new_nodes; for (int i : children[root[b]]) { int p = parent[i]; new_nodes.push_back(i); new_nodes.push_back(p); if (i == p) continue; inserts.push_back({i, p}); inserts.push_back({p, i}); } children[root[b]].clear(); sort(inserts.begin(), inserts.end()); inserts.erase(unique(inserts.begin(), inserts.end()), inserts.end()); sort(new_nodes.begin(), new_nodes.end()); new_nodes.erase(unique(new_nodes.begin(), new_nodes.end()), new_nodes.end()); for (int node : new_nodes) { children[root[a]].push_back(node); } for (auto [a, b] : inserts) { adj[a].push_back(b); } iter = 0; dfs_reconstruct(b, depth[a] + 1, a, root[a]); for (auto [a, b] : inserts) { adj[a].clear(); } } } for (int i = 0; i < n; i++) { if (find(i) != find(parent[i])) cout << i + 1 << " " << parent[i] + 1 << "\n"; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...