0

0

在有向图中找到两个顶点之间是否存在路径

WBOY

WBOY

发布时间:2023-08-29 12:49:06

|

1550人浏览过

|

来源于tutorialspoint

转载

在有向图中找到两个顶点之间是否存在路径

在计算机科学和图论中,解决各种现实生活模型场景的方案严重依赖于有向图。这些专门的图由通过指向其他顶点的有向边连接的顶点组成。确定两个指定点之间是否存在路径是使用有向图的一个典型难题。在本文中,我们将探讨使用C++解决这个困境的各种方法,包括每个过程所需的语法,以确保事情易于理解。此外,我们将详细介绍精心说明每种方法的算法,并包含两个可执行的代码示例。

语法

在深入了解具体细节之前,理解支撑这里方法论的语言结构是至关重要的。因此,在继续查看代码示例之前,让我们首先检查这个语法。

bool isPathExists(int startVertex, int endVertex, const vector>& graph);

算法

在有向图中找到两个顶点之间的路径可以使用多种技术来解决。本文将重点讨论两种广泛使用的方法−

方法一:深度优先搜索(DFS)

  • 创建一个visited数组来在遍历过程中跟踪已访问的顶点。

  • 将visited数组的所有元素初始化为false。

  • 将startVertex标记为已访问。

  • 如果起始顶点与结束顶点相同,则返回true,表示存在一条路径。

  • 对于当前顶点的每个相邻顶点,以相邻顶点作为新的起始顶点,递归调用isPathExists函数。

  • 如果任何递归调用返回true,则返回true。

  • 如果没有递归调用返回true,则返回false。

方法二:广度优先搜索(BFS)

  • 创建一个visited数组来在遍历过程中跟踪已访问的顶点。

  • 将visited数组的所有元素初始化为false。

  • 创建一个队列来存储待处理的顶点。

  • 将startVertex加入队列,并标记为已访问。

  • 如果队列不为空,执行以下操作:

    FreeTTS
    FreeTTS

    FreeTTS是一个免费开源的在线文本到语音生成解决方案,可以将文本转换成MP3,

    下载
  • 从队列中出队一个顶点。

  • 如果出队的顶点与endVertex相同,则返回true,表示存在一条路径。

  • 对于每个被出队的顶点的相邻顶点,如果它尚未被访问,则将其入队并标记为已访问。

  • 如果队列变为空并且没有找到路径,则返回 false。

示例1:深度优先搜索(DFS)方法

#include 
#include 
using namespace std;

bool isPathExists(int startVertex, int endVertex, const vector>& graph) {
   vector visited(graph.size(), false);
   visited[startVertex] = true;
  
   if (startVertex == endVertex)
      return true;
  
   for (int adjVertex : graph[startVertex]) {
      if (!visited[adjVertex] && isPathExists(adjVertex, endVertex, graph))
         return true;
   }
  
   return false;
}

int main() {
   // Example usage
   int numVertices = 6;
   vector> graph(numVertices);
   graph[0] = {1, 2};
   graph[1] = {3};
   graph[2] = {1};
   graph[3] = {4, 5};
   graph[4] = {};
   graph[5] = {4};

   int startVertex = 0;
   int endVertex = 5;

   if (isPathExists(startVertex, endVertex, graph))
      cout << "A path exists between " << startVertex << " and " << endVertex << endl;
   else
      cout << "No path exists between " << startVertex << " and " << endVertex << endl;

   return 0;
}

输出

A path exists between 0 and 5

代码从定义一个名为isPathExists的函数开始,该函数接受startVertex、endVertex和以邻接表表示的图作为参数。它初始化了一个名为visited的布尔向量,用于跟踪已访问的顶点。在执行此函数时,它首先通过比较它们来检查startVertex和endVertex是否相同。

当这些顶点在此上下文中完全重合时,函数立即返回true。

如果情况不是这样的,并且它们彼此不同,将采取另一种行动来检查它们之间的邻接性,以确定它们之间是否存在路径。

这个过程涉及反复迭代起始顶点的相邻顶点;每次迭代都会使用新搜索到的顶点作为新的起始点,通过递归调用“isPathExists”来继续寻找可用路径。这个循环会重复进行,直到所有可能的路径耗尽或者找到一条成功的路径。

如果这些重复调用中的任何一个检测到连接起始节点和结束节点的潜在边缘,那么这种筛选的输出将意味着这两个节点之间确实存在可用的互连。因此,将立即返回True。

否则,当算法中设置的复杂度导致不存在可用路由时,将启动故障安全的循环动作。在出现这种结果时,它返回False,对节点之间的连接失败表示遗憾。

示例2:广度优先搜索(BFS)方法

#include 
#include 
#include 
using namespace std;

bool isPathExists(int startVertex, int endVertex, const vector>& graph) {
   vector visited(graph.size(), false);
   visited[startVertex] = true;
  
   queue verticesQueue;
   verticesQueue.push(startVertex);
  
   while (!verticesQueue.empty()) {
      int currVertex = verticesQueue.front();
      verticesQueue.pop();
  
      if (currVertex == endVertex)
         return true;
  
      for (int adjVertex : graph[currVertex]) {
         if (!visited[adjVertex]) {
            visited[adjVertex] = true;
            verticesQueue.push(adjVertex);
         }
      }
   }
  
   return false;
}

int main() {
   // Example usage
   int numVertices = 6;
   vector> graph(numVertices);
   graph[0] = {1, 2};
   graph[1] = {3};
   graph[2] = {1};
   graph[3] = {4, 5};
   graph[4] = {};
   graph[5] = {4};

   int startVertex = 0;
   int endVertex = 5;

   if (isPathExists(startVertex, endVertex, graph))
      cout << "A path exists between " << startVertex << " and " << endVertex << endl;
   else
      cout << "No path exists between " << startVertex << " and " << endVertex << endl;

   return 0;
}

输出

A path exists between 0 and 5

该代码定义了一个isPathExists函数,该函数接受startVertex、endVertex和以邻接表表示的图作为参数。它初始化了一个名为visited的布尔向量来跟踪访问过的顶点,并初始化了一个名为verticesQueue的队列来存储待处理的顶点。

该函数从将startVertex入队并标记为已访问开始。我们的算法的运行始于进入一个迭代循环,只要其处理队列结构中仍有项目存在,该循环就会持续进行。随着这个结构化的重复的进行,每个周期执行两个检查:首先验证当前迭代的出队顶点是否与之前执行中指定的目标终点匹配;如果两者成功匹配,则返回'true',否则继续下一步,即探索附近的外围点。在这个探索过程中,任何相邻的未探索顶点在放入队列进行更深层次的迭代检查之前都会被标记为'visited',并测试它们是否与endVertex匹配。

在所有的探索和验证都成功之后,如果队列中没有任何添加,该函数将返回false。

结论

在计算机科学的发展中,导航有向图的复杂性可能会构成一个基本问题。为了减轻这些挑战,我们的目标之一是探索使用C++实现的两种常见方法。深度优先搜索(DFS)和广度优先搜索(BFS)是这些技术的前沿,它们提供了逐步演示每个算法的过程和工作代码示例。一旦掌握了这些方法,就可以在处理多个设置(如路由网络或分析社交连接框架)的路径查找障碍时激发新的潜力,并且在增强开发阶段中作为有价值的起点。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

404

2023.08.14

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

28

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

20

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

52

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.2万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号