DFS求有向图强联通分量

本文介绍了如何利用两次深度优先搜索(DFS)和一次转置图来找出有向图的强联通分量。通过分析强联通分量的性质,提出在第一次DFS后,完成时间最晚的点所在的强联通分量不会有指向其他分量的边。通过转置图再次DFS,可以确定每个强联通分量。文章提供了伪代码帮助理解这一过程。
摘要由CSDN通过智能技术生成

在算法导论的图论算法里,有一个小节讲的是利用两次DFS和一次转置图来求有向图的强联通分量,觉得整个解法很有意思,所以想分享给大家一起瞅瞅。


先修知识:

主要是DFS的运行过程,以及我们将在对某个点完成DFS过程时标记一个完成时间,在这里用十分伪的代码描述一下。

void DFS(Graph G,Vertex u)
{
	visit u;
	for each Vertex v adjacent to u
		if(v is not visited)
			DFS(G,v);
	u.f = ++time;								//我们用f来表示完成时间这一属性,并且我们有一个全局时间变量time
}

主要思路:

不妨先来思考一下,如果我们要得到一个强联通分量,或者说证明我们所选取的分量是强联通分量,该怎么做?

让我们从定义开始,强联通分量里任意两个点互相可以达到。毫无疑问这样是很麻烦的,如果有办法将问题规模缩小到一个点和其他点的关系,问题将会好解决得多。不妨来试一试,假设我们现在已经能够满足,某个特定的点A可以达到分量里任何其他一个点。想到这里,答案就比较清晰了。既然A点能达到其他任何一个点,那如果其他任何一点能达到点A,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值