#include <bits/stdc++.h>
#define fi first
#define se second
#define all(v) v.begin(), v.end()
#define eb emplace_back
#define em emplace
using namespace std;
typedef long long ll;
typedef pair <int, int> pii;
typedef pair <ll, ll> pll;
const int MAX = 101010;
const int INF = 1 << 30;
const ll LINF = 1LL << 60;
struct UFT {
vector <int> p;
UFT(int n) {
p.resize(n+1);
for(int i = 1; i <= n; i++) p[i] = i;
}
int find(int x) {
return p[x] == x ? p[x] : p[x] = find(p[x]);
}
void uni(int x, int y) {
x = find(x), y = find(y);
p[max(x, y)] = min(x, y);
}
};
vector <int> g[MAX];
int low[MAX], ord[MAX], cnt = 0;
void dfs(int x, int pa) {
ord[x] = low[x] = ++cnt;
for(auto i : g[x]) {
if(i == pa) continue;
if(ord[i] == 0) {
dfs(i, x);
low[x] = min(low[x], low[i]);
}
else if(ord[i] < ord[x]) {
low[x] = min(low[x], ord[i]);
}
}
for(auto i : g[x]) {
if(i == pa) continue;
if(low[i] > ord[x]) cout << x << ' ' << i << '\n';
}
}
int main() {
ios::sync_with_stdio(false); cin.tie(0);
int n, m;
cin >> n >> m;
UFT t1(n), t2(n);
for(int i = 1; i <= m; i++) {
int u, v; cin >> u >> v;
if(t1.find(u) != t1.find(v)) {
t1.uni(u, v);
g[u].eb(v), g[v].eb(u);
}
else if(t2.find(u) != t2.find(v)) {
t2.uni(u, v);
g[u].eb(v), g[v].eb(u);
}
}
for(int i = 1; i <= n; i++) {
if(ord[i] == 0) dfs(i, 0);
}
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
4 ms |
2680 KB |
Output is correct |
2 |
Incorrect |
4 ms |
2684 KB |
Wrong number of edges |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
8 ms |
3368 KB |
Output is correct |
2 |
Incorrect |
8 ms |
3064 KB |
Wrong number of edges |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
132 ms |
8568 KB |
Output is correct |
2 |
Incorrect |
128 ms |
8284 KB |
Wrong number of edges |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
217 ms |
13596 KB |
Wrong number of edges |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
367 ms |
21640 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
493 ms |
31396 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
767 ms |
45192 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
996 ms |
58232 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1247 ms |
65536 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1507 ms |
65536 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |