제출 #52624

#제출 시각아이디문제언어결과실행 시간메모리
52624Alexa2001Pipes (CEOI15_pipes)C++17
20 / 100
1181 ms14196 KiB
#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 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...