【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

相关文章

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

Python进阶之列表推导式的10个核心技巧

《Python进阶之列表推导式的10个核心技巧》在Python编程中,列表推导式(ListComprehension)是提升代码效率的瑞士军刀,本文将通过真实场景案例,揭示列表推导式的进阶用法,希望对... 目录一、基础语法重构:理解推导式的底层逻辑二、嵌套循环:破解多维数据处理难题三、条件表达式:实现分支

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD

javaSE类和对象进阶用法举例详解

《javaSE类和对象进阶用法举例详解》JavaSE的面向对象编程是软件开发中的基石,它通过类和对象的概念,实现了代码的模块化、可复用性和灵活性,:本文主要介绍javaSE类和对象进阶用法的相关资... 目录前言一、封装1.访问限定符2.包2.1包的概念2.2导入包2.3自定义包2.4常见的包二、stati