当前位置: 首页 > news >正文

6.3图的遍历

图的遍历是指从某点出发,按照某种搜索方式沿着边访问图中所有节点

图的遍历算法主要有两种:广度优先,深度优先

都需要辅助数组visited[]来记录节点是否被访问过

6.3.1广度优先搜索

like层次遍历,需要辅助队列

代码实现


#include<stdio.h>
#define maxnum 15
bool visited[maxnum];//定义辅助数组
void BFSTraverse(Graph G) {for (int i = 0; i < G.vexnum; i++){visited[i] = false;}//初始化数组initQueue(Q);//初始化队列for (int i = 0; i < G.vexnum; i++)//从0号顶点开始遍历{if (!visited[i]) {BFS(G,i);//广度优先遍历}}
}
void BFS(Graph G,int i){visit(i);//访问visited[i] = true;//改为tEnQueue(Q,i);//入队while (!isEmpty(Q)) {//判断队列是否为空DeQueue(Q,i);//输出队列第一个元素for ( p = FirstNeghbor(G,i); p >0; p=NextNeighbor(G,i,w)){if (!visited[p]) {visit(p);visited[p] = true;EnQueue(Q, p);}}}}

 广度优先遍历过程

从顶点1出发:12563748

从顶点3出发:34678215

性能分析

邻接表和邻接矩阵空间复杂度

邻接表时间复杂度

邻接矩阵的时间复杂度

广度优先生成树

在广度遍历中可以得到一颗遍历树,为广度优先生成树

邻接矩阵唯一,生成树唯一

邻接表不唯一,生成树不唯一

6.3.2深度优先搜索

belike树的先序遍历

代码实现

#include<stdio.h>
#define maxnum 15
bool visited[maxnum];//定义辅助数组
void DFSTraverse(Graph G) {for (int i = 0; i < G.vexnum; i++){visited[i] = false;}//初始化数组for (int i = 0; i < G.vexnum; i++)//从0号顶点开始遍历{if (!visited[i]) {DFS(G, i);//深度优先遍历}}
}
void DFS(Graph G, int i) {visit(i);//访问visited[i] = true;//改为tfor (p = FirstNeghbor(G, i); p > 0; p = NextNeighbor(G, i, w)){if (!visited[p]) {DFS(G, p);}
}

深度优先遍历过程

从2出发:21563478

从3出发:34762158

性能分析

深度优先生成树和生成森林

非连通图可通过深度优先产生n棵生产树

6.3.3图的遍历与图的连通性

to无向图:调用DFS/BFS的次数=连通分量数

to有向图:强连通分量只调用一次DFS/BFS;

若从起始节点到其他节点都有路径,则只需调用一次

http://www.lryc.cn/news/432819.html

相关文章:

  • 2024数学建模国赛选题建议+团队助攻资料(已更新完毕)
  • 大学课程-人机交互期末复习
  • 畅游5G高速网络:联发科集成Wi-Fi6E与蓝牙5.2的系统级单芯片MT7922
  • SpringSecurity原理解析(一)
  • 在Ubuntu 20.04上安装Nginx的方法
  • 基于苹果Vision Pro的AI NeRF方案:MetalSplatter
  • linux系统中,计算两个文件的相对路径
  • [数据集][目标检测]抽烟检测数据集VOC+YOLO格式22559张2类别
  • C和指针:结构体(struct)和联合(union)
  • [数据集][目标检测]电动车头盔佩戴检测数据集VOC+YOLO格式4235张5类别
  • 软件工程知识点总结(2):需求分析(一)——用例建模
  • 2024 年高教社杯全国大学生数学建模竞赛C题—农作物的种植策略(讲解+代码+成品论文助攻,均已更新完毕)
  • ?.操作符是什么
  • ArcGIS出图格网小数位数设置
  • 数学建模_缺失值处理_拉格朗日、牛顿插值(全)
  • 算法题之水壶问题
  • Java项目: 基于SpringBoot+mysql蜗牛兼职网兼职平台管理系统(含源码+数据库+答辩PPT+毕业论文)
  • C#数组中的Rank,GetUpperBound(), GetLength()
  • Android应用开发项目式教程——序
  • 【Spring Boot 3】【Web】统一处理 HTTP 请求体
  • uni-app开发微信小程序
  • Qt开发框架--完整的软件开发框架
  • Python爬虫-Amazon亚马逊oData参数
  • Q215 数组中第K大的元素
  • Java8特性:分组、提取字段、去重、过滤、差集、交集
  • Maven快速上手使用指南的笔记
  • MySQL面试题大全和详解,含SQL例子
  • java-redis-雪崩
  • 如何在mac上玩使命召唤手游?苹果电脑好玩的第一人称射击游戏推荐
  • SimHash算法详解与应用