【408DS算法题】039进阶-判断图中路径是否存在

2024-09-09 05:36

本文主要是介绍【408DS算法题】039进阶-判断图中路径是否存在,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Index

    • 题目
    • 分析实现
    • 总结

题目

对于给定的图G,设计函数实现判断G中是否含有从start结点到stop结点的路径。

分析实现

对于图的路径的存在性判断,有两种做法:(本文的实现均基于邻接矩阵存储方式的图)

1.图的BFS

BFS的思路相对比较直观——从起始结点出发进行层次遍历,遍历过程中遇到结点i就表示存在路径start->i,故只需判断每个结点i是否就是stop

具体实现如下:

// BFS版本判断路径存在
bool hasPathBFS(Graph& G, int start, int stop){if (start == stop)return true;vector<bool> visited(G.vexnum, false);queue<int> q;q.push(start);visited[start] = true;while(!q.empty()){int cur = q.front();q.pop();for(int i=0; i<G.vexnum; i++){// 没有边if(G.edge[cur][i] == 0){continue;}// 找到路径if(i == stop){return true;}if(!visited[G.edge[cur][i]]){q.push(i);visited[i] = true;}}}return false;
}

2.图的DFS

理解的图DFS版本的思想,首先需要根据递归的思想,推理出递归函数的作用——判断图中是否存在路径cur->stop,再将这一“功能”运用到遍历中,思路就会非常简单。

具体实现如下:

// DFS实现辅助函数
bool hasPathDFSUtil(Graph& G, int cur, int stop, vector<bool>& visited){if(cur == stop){return true;}visited[cur] = true;for(int i = 0; i < G.vexnum; i++){// 重点递归判断 - 存在边[cur-i] + 未访问过i + *存在路径[i-stop]if(G.edge[cur][i] == 1 && !visited[i] && hasPathDFSUtil(G, i, stop, visited)){return true;}}
}
// DFS判断路径存在
bool hasPathDFS(Graph& G, int start, int stop){vector<bool> visited(G.vexnum, false);return hasPathDFSUtil(G, start, stop, visited);
}

总结

以上就是通过BFS和DFS两种方式实现的图的路径的存在性判断。

对于递归函数,刚开始尝试的时候总是会想不到思路。
对此,只需去想递归函数的统一的实现思路——假设函数功能已经实现,先写出递归基,再运用“更小规模”的函数调用来实现递归函数。

这篇关于【408DS算法题】039进阶-判断图中路径是否存在的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

利用Python把路径转为绝对路径的方法

《利用Python把路径转为绝对路径的方法》在Python中,如果你有一个相对路径并且想将其转换为绝对路径,你可以使用Path对象的resolve()方法,Path是Python标准库pathlib中... 目录1. os.path.abspath 是什么?怎么用?基本用法2. os.path.abspat

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet