This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#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;
for(auto son : v[node])
{
if(son == dad) 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)
{
sort(v[i].begin(), v[i].end());
v[i].erase( unique(v[i].begin(), v[i].end()), v[i].end() );
}
for(i=1; i<=n; ++i)
if(!level[i]) solve(i);
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |