Submission #975238

#TimeUsernameProblemLanguageResultExecution timeMemory
975238duckindogPipes (CEOI15_pipes)C++17
0 / 100
1522 ms65536 KiB
#include <bits/stdc++.h> using namespace std; const int N = 100'000 + 1; int n, m; vector<int> ad[N]; int low[N], num[N], it; void dfs(int u, int p = -1) { low[u] = num[u] = ++it; for (const auto& v : ad[u]) { if (v == p) continue; if (!low[v]) { dfs(v, u); low[u] = min(low[u], low[v]); if (low[v] == num[v]) cout << u << " " << v << "\n"; } else low[u] = min(low[u], num[v]); } } int32_t main() { cin.tie(0)->sync_with_stdio(0); cin >> n >> m; for (int i = 1; i <= m; ++i) { int u, v; cin >> u >> v; ad[u].push_back(v); ad[v].push_back(u); } for (int i = 1; i <= n; ++i) if (!low[i]) dfs(i); }
#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...