Cod sursa(job #418922)
#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;
}