【算法概论】图论算法:有向图中环的判断问题

2024-03-10 01:38

本文主要是介绍【算法概论】图论算法:有向图中环的判断问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述:

       给定一个有向图,要求使用深度优先搜索策略,判断图中是否存在环。

算法分析❗:

       判断图中是否存在环,要涉及到图的拓扑排序。回看数据结构的书?,上面是这样写的:

       基于环性质,在对有向图进行深度优先搜索?中,可以检查图中是否存在环,并进行拓扑排序。为检测图中是否存在反向边,可使用类似二叉树后序遍历的思想。即,在深度优先搜索中,对当前被访问的任一顶点 v 做访问标记,但不立即输出,而是将输出推迟到它的所有可达顶点(后继顶点)被输出之后。为了保证输出的顶点序列具有拓扑顺序,输出时应将顶点 v 插在它的所有后继顶点之前。这样,在深度优先搜索过程中每个顶点有 未被访问、已访问、已输出 三种状态。对任一顶点 v ,初始状态为 未被访问。当一个顶点被访问后,其状态由 未被访问 变为 已访问,接着检查它的每一个邻接点的状态。若某个邻接点的状态为 已访问,则表明图中有环。

       1、关于邻接表表示法中的拓扑排序问题,在【数据结构】图 - 邻接表表示法 这篇中,已经复习过。

       2、同时,在上述一段话中,还提到了DFS时顶点的三种状态:

       vis 标记 一个顶点的访问情况。

       vis = 0,表示该顶点没没有被访问;
       vis = 1,表示该顶点已经被访问,但其子孙后代还没被访问完 —— 还没从该点返回;
       vis = 2,表示该顶点已经被访问,其子孙后代也已经访问完 —— 已经从该顶点返回。

       3、上面一段话提到一个概念 —— 反向边,❀ 这就跟上课的内容有点联系啦 ?

       上课时,有几个概念:树边、前向边、回边、横跨边,从定义可以看出,这几个概念是图进行DFS时才有的概念。

       进行概念阐述时,让我们与顶点的三种状态结合起来。

       DFS过程中,对于一条边 u → v,

       vis[v] = 0,v 是 首次发现,边 u → v是树边;

       vis[v] = 1,说明 v 已经被访问,但其子孙后代还没有被访问完(正在访问中),而 u 又指向 v,说明 u 就是 v 的子孙后代,

这篇关于【算法概论】图论算法:有向图中环的判断问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/792594

相关文章

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.

Seata之分布式事务问题及解决方案

《Seata之分布式事务问题及解决方案》:本文主要介绍Seata之分布式事务问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Seata–分布式事务解决方案简介同类产品对比环境搭建1.微服务2.SQL3.seata-server4.微服务配置事务模式1

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

Spring MVC跨域问题及解决

《SpringMVC跨域问题及解决》:本文主要介绍SpringMVC跨域问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录跨域问题不同的域同源策略解决方法1.CORS2.jsONP3.局部解决方案4.全局解决方法总结跨域问题不同的域协议、域名、端口

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-