Cod sursa(job #418922)

Utilizator dead_knightTitei Paul Adrian dead_knight Data 16 martie 2010 18:33:15
Problema Componente biconexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.37 kb
#include<fstream>
#include<cstdio>
#include<vector>
#define pb push_back
#define MAX 100004
using namespace std;

vector<int> G[MAX], CBC[MAX];
int v[MAX], n, nr, nrc, c[MAX], lvl[MAX];

struct data{
    int x, y;
} s[MAX];

void citire()
{
    int m;
    ifstream fin("biconex.in");
    fin>>n>>m;
    for(int i=1;i<=m;i++)
    {
        int x,y;
        fin>>x>>y;
        G[x].pb(y);
        G[y].pb(x);
    }
}

void add(int k, int vecin)
{
    nrc++;
    do
    {
        CBC[nrc].pb(s[nr].y);
        nr--;
    }while(s[nr+1].x!=k || s[nr+1].y!=vecin);
    CBC[nrc].pb(s[nr+1].x);
}

void dfs(int k, int tata)
{
    c[k]=lvl[k]=lvl[tata]+1;
    v[k]=1;
    for(int i=0;i<G[k].size();i++)
    {
        int vecin=G[k][i];
        if(!v[vecin])
        {
            s[++nr].x=k;
            s[nr].y=vecin;
            dfs(vecin, k);
            if(c[vecin]<c[k])
                c[k]=c[vecin];
            if(c[vecin]>=lvl[k])
                add(k,vecin);
        }
        else if(tata!=vecin && c[vecin]<c[k])
            c[k]=c[vecin];
    }
}

int main()
{
    freopen("biconex.out","w",stdout);
    citire();
    int i;
    dfs(1,0);
    printf("%d\n", nrc);
    for(i=1;i<=nrc;i++)
    {
        for(int j=0;j<CBC[i].size();j++)
            printf("%d ", CBC[i][j]);
        printf("\n");
    }
    return 0;
}