tarjan模板

本文详细介绍使用Tarjan算法进行强连通分量分析的过程。通过递归遍历图中每个节点并利用dfn和low数组记录节点的状态,Tarjan算法能够有效地找出所有强连通分量。文中提供了一个具体的实现代码示例。
	int tot,bel[MAXV+D];//tot代表强连通分量总数,bel数组代表点属于第几个连通分量
	int dfn[MAXV+D],low[MAXV+D],ind=0; 
	int stack[MAXV+D],top;
	bool ins[MAXV+D];
	void tarjan(int x)
	{
		dfn[x]=low[x]=++ind;
		ins[stack[++top]=x]=true;
		for(int i=head[x],y;i;i=e[i].next)
			if(!dfn[y=e[i].y])
			{
				tarjan(y);
				if(low[y]<low[x])
					low[x]=low[y];
			} 
			else if(ins[y]&&dfn[y]<low[x])
				low[x]=dfn[y];
		}
		if(dfn[x]==low[x])
		{
			int k;tot++;
		do{
			k=stack[top--];
			ins[k]=false;
			bel[k]=tot;
		}while(k!=x);
	}
}

  

转载于:https://www.cnblogs.com/mybing/p/8724214.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值