Cod sursa(job #2798174)

Utilizator bogdan2405Strat Bogdan-Valentin bogdan2405 Data 10 noiembrie 2021 23:18:42
Problema Componente biconexe Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.92 kb
#include<bits/stdc++.h>

using namespace std;
ifstream f("biconex.in");
ofstream g("biconex.out");

vector<int> visited,adjList[100001],low,id;
int temp=0,cnt=0;
vector<vector<int>> res;
void DFS(int x, int parent){
    int i;
    id[x]=temp;
    low[x]=temp;
    temp++;

    for(i=0;i<adjList[x].size();++i){
        if(parent!=adjList[x][i]){
            if(visited[adjList[x][i]-1]==0){
                visited[adjList[x][i]-1]++;
                DFS(adjList[x][i],x);

                low[x-1]=min(low[x-1],low[adjList[x][i]-1]);

                if(id[x-1]<low[adjList[x][i]-1]){
                    cnt++;
                    res.push_back({x,adjList[x][i]});
                }
                   
            }
            else{
                low[x-1]=min(low[x-1],id[adjList[x][i]-1]);

            }
        }
    }

}

int main(){
    int i;

    int n,m,a,b;
    f>>n>>m;

    for(i=0;i<n;++i){
        visited.push_back(0);
        id.push_back(0);
        low.push_back(0);
    }

    for(i=0;i<m;++i){
        f>>a>>b;
        adjList[a].push_back(b);
        adjList[b].push_back(a);

    }

    visited[0]++;
    DFS(1,-1);

    unordered_map<int,vector<int>>umap;

    for(i=0;i<low.size();++i){
        umap[low[i]].push_back(i+1);
    }

    int j;

    /*for(i=0;i<low.size();++i)
        cout<<low[i]<<' ';
    for(auto x:umap){
        cout<<x.first<<": ";
        for(i=0;i<x.second.size();++i){
            cout<<x.second[i]<<' ';
        }
        cout<<'\n';
    }*/
    vector<int> aux;
    for(auto x:umap){
        if(x.second.size()>1){
            cnt++;
            for(j=0;j<x.second.size();++j){
                aux.push_back(x.second[j]);
                cout<<x.second[j]<<' ';
            }
            res.push_back(aux);
            aux.clear();
        }
    }
    g<<cnt<<'\n';
    for(i=0;i<res.size();++i){
        for(j=0;j<res[i].size();++j){
            g<<res[i][j]<<' ';
        }
        g<<'\n';
    }
    return 0;
}