单连通图的判断
创始人
2024-03-01 14:52:11
0

在这里插入图片描述

  1. 单连通图的判断算法:
    (1)对每个点进行dfs得到一棵dfs树;
    (2)判断是否存在前向边和横向边,若有则必定存在两个点之间有至少2条简单路径,因此该图不属于单连通图;
    (3)若对所有dfs树不存在(2)中情况,则该图是单连通图。
  2. 算法时间复杂度:对VVV个点进行dfs,每次dfs的时间为O(V+E)O(V+E)O(V+E),因此总时间复杂度为O(V∗(V+E))O(V*(V+E))O(V∗(V+E)).
  3. 算法正确性证明:
    必要性(对于单连通图,每个点出发的dfs树中不存在前向边和横向边):假设点A,B之间存在前向边AB,根据前向边的定义,应存在另外一条由树边组成的路径A->B,不满足至多1条简单路径的要求;
    假设点A,B之间存在横向边AB,根据算法步骤易知A,B应在以某个点为根的dfs树中,设为R,那么在点R,B之间至少存在R->A->B和R->B两条路径,不满足至多1条简单路径的要求;
    充分性(对于一个图,每个点出发的dfs树中不存在前向边或横向边则是单连通图):等价于证明逆否命题,若图中A,B两个点之间存在2条路径,则一定对应存在的前向边或者横向边。设A,B之间存在路径(A,x1,x2,...,xn,B)(A,x_1,x_2,...,x_n,B)(A,x1​,x2​,...,xn​,B)以及(A,y1,y2,...,ym,B)(A,y_1,y_2,...,y_m,B)(A,y1​,y2​,...,ym​,B),
    当m,nm,nm,n均大于0时,根据白色路径定理,xix_ixi​,yjy_jyj​以及B均为A的子孙,因此(xn,B)(x_n,B)(xn​,B)和(ym,B)(y_m,B)(ym​,B)必有一个是横向边;(此处有纰漏)
    当m=0,n>0m=0,n>0m=0,n>0时,(A,B)(A,B)(A,B)是前向边或者(xn,B)(x_n,B)(xn​,B)是横向边;当m>0,n=0m>0,n=0m>0,n=0时类同。
    以上。

以下是老师ppt上的证明:
大题思路相同,但我证明最后“因此(xn,B)(x_n,B)(xn​,B)和(ym,B)(y_m,B)(ym​,B)必有一个是横向边”的论断是错的,可以修补。

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
分为两条路径上存在v的后代和存在v的后代两种情况。第一种可以断定(xr,v)(x_r,v)(xr​,v)和(yt,v)(y_t,v)(yt​,v)中有一条是前向边或交叉边;第二种,存在这样一条搜索路径u→yj→v→w→xk→vu\rightarrow y_j \rightarrow v \rightarrow w \rightarrow x_k \rightarrow vu→yj​→v→w→xk​→v(如下图所示,标号对应关系:j=tj=tj=t,k=rk=rk=r),此时(yk,v)(y_k,v)(yk​,v)是树边,而(xj,v)(x_j,v)(xj​,v)是返回边,但我们仍可以找到这样的两条边(xi−1,xi)(x_{i-1},x_i)(xi−1​,xi​)和(yi−1,yi)(y_{i-1},y_i)(yi−1​,yi​)其中有一条是前向边或交叉边。

请添加图片描述

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...