ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

图的连通性算法

2019-03-02 08:51:36  阅读:238  来源: 互联网

标签:标号 连通 连通性 DFS 算法 num 反图 分量


Kosaraju算法

适用范围及时间复杂度

线性时间算法,找一个有向图的强连通分量(分量中所有点都是连通的)。

算法原理

首先有一个定义,名曰反图。何为反图?即将图中所有边反向操作。

上图样例即为一对反图。在整副图中,有三个强连通分量,即:1 2 5,3,4.如果把这副图所有边反向后,得到的同样是三个强连通分量。

即原图和反图的强连通分量的数量和每个强连通分量中的元素都是一样的,只是顺序不一样。

核心思想

先对原图进行DFS(深度优先搜索),保存每个节点退出DFS的次序,即后序数。

然后再用后序数最大点为顶点作为始点,对反图进行DFS。如此反复,直到访问完反图的所有节点为止。

把每一次对反图进行DFS所产生的顶点进行标号,即这些顶点为同一个强分支。

代码实现

这里以int cnt表示分支标号,每个点所属的分支标号用num[MAXN]记录。

用vect[MAXN]来存放后序。

    for(int i=n-1;i>=0;i--){
        if(!num[vect[i]]){//如果这个节点还没有被标号 
            cnt++;//创建新的分支 
            rdfs(vect[i]);//通过深搜把该分支节点标号 
        }
    }

void rdfs(int u){
    if(num[u]){
        return;
    }
    num[u]=cnt;
    for(int i=0;i<gt[u].size();i++){
        rdfs(gt[u][i]);
    }
} 

 

标签:标号,连通,连通性,DFS,算法,num,反图,分量
来源: https://www.cnblogs.com/Uninstalllingyi/p/10459659.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有