#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int Nmax = 1e5 + 5;
int n, m, i, x, y;
int level[Nmax], low[Nmax];
vector<int> v[Nmax];
struct Forest
{
int t[Nmax];
void clear()
{
int i;
for(i=1; i<=n; ++i) t[i] = i;
}
int boss(int x)
{
if(t[x] == x) return x;
return t[x] = boss(t[x]);
}
void unite(int x, int y)
{
x = boss(x), y = boss(y);
t[x] = y;
}
} A, B;
void solve(int node, int dad = 0)
{
level[node] = low[node] = level[dad] + 1;
bool ok = 0;
for(auto son : v[node])
{
if(son == dad && !ok)
{
ok = 1;
continue;
}
if(level[son])
{
low[node] = min(low[node], level[son]);
continue;
}
solve(son, node);
low[node] = min(low[node], low[son]);
if(low[son] == level[son])
cout << node << ' ' << son << '\n';
}
}
int main()
{
// freopen("input", "r", stdin);
// freopen("output", "w", stdout);
cin.sync_with_stdio(false);
cin >> n >> m;
A.clear(); B.clear();
while(m--)
{
cin >> x >> y;
if(B.boss(x) == B.boss(y)) continue; /// same bcomp
if(A.boss(x) != A.boss(y)) A.unite(x, y);
else B.unite(x, y);
v[x].push_back(y);
v[y].push_back(x);
}
for(i=1; i<=n; ++i)
if(!level[i]) solve(i);
return 0;
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
3 ms |
2688 KB |
Output is correct |
2 |
Correct |
4 ms |
2688 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
8 ms |
3172 KB |
Output is correct |
2 |
Correct |
8 ms |
3044 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
99 ms |
3040 KB |
Output is correct |
2 |
Correct |
102 ms |
2908 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
168 ms |
3832 KB |
Output is correct |
2 |
Correct |
204 ms |
3320 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
286 ms |
5340 KB |
Output is correct |
2 |
Correct |
243 ms |
4960 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
426 ms |
10600 KB |
Output is correct |
2 |
Correct |
358 ms |
7164 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
645 ms |
11876 KB |
Output is correct |
2 |
Correct |
596 ms |
9020 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
833 ms |
14044 KB |
Output is correct |
2 |
Correct |
780 ms |
9084 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
1038 ms |
14040 KB |
Output is correct |
2 |
Correct |
930 ms |
9208 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
1213 ms |
13456 KB |
Output is correct |
2 |
Correct |
1113 ms |
10508 KB |
Output is correct |