6.2.4图的基本操作 6.3.1图的广度优先遍历 6.3.2图的深度优先遍历

news2025/1/11 23:43:08

6.2.4图的基本操作

 

考研里面只考邻接矩阵和邻接表的存储结构

 思想较为简单见video

重点理解时间复杂度的遍历原理

6.3.1图的广度优先遍历(BFS)(Breadth first traversal)

我们从树的广度优先遍历入手去看图的广度优先遍历的思想

 首先从1根节点开始,向着孩子节点234,

6.3.1图的广度优先遍历

加入先从2结点出发,到1,6结点,接着从1,6结点出发,就是遍历到537.

再从5,3,7出发就是到4,8。

树VS图

 

就比如说从6号结点搜索相邻的结点的时候(237),会搜索到已经访问过的结点2。

我们就需要对已经访问过的节点进行标记。

 1.找到与一个顶点相邻的的所有顶点

 应用这两个函数

邻接矩阵和邻接表法实现起来会有所区别:

 2.标记那些顶点被访问过

用一个布尔类型的数组进行存储,该节点是否被访问过。

 

一考试VISITED数组都为false,当元素入队以后对应的序号的数组值就变为True。

 接着DeQueue让2号结点出列,用FirstNeighbour和NextNeighbour进行遍历。

如果对用visited数组值为false,就访问这个结点,并对这个节点作标记,让他入队列。

 接着让一号节点出队,处理1号结点的邻接结点。

 

 

 接着处理队头结点6号结点,DeQueue先出队6,再把237为6的邻接结点,由于2对应的visitd已经为True,所以我把37放入队尾。

 接下来处理5号结点,5号结点的邻接结点已经被访问过。

 

 接下来处理3号结点,出队,只有4号节点是没有被访问过的。

那如果是从顶点1出发进行广度优先遍历呢?

 邻接结点我们是按照顶点递增的次序来排列的,所以1之后是25而不是52.

算法当为非连通图时,会存在问题,无法遍历完所有顶点。

 我们可以对之前的算法进行封装,命名为BFS(Graph G,int v)

然后再BFSTraverse(breadth first search)调用BFS函数从0号结点开始遍历。

从1号结点出发,我们可以Traverse  1-8号结点。

 第一次调用玩BFS函数之后,1-8数组的值都变为了True。

接着会继续往后遍历,直到遍历到9号结点。

 

这个无向图有两个极大连通子图,也就是两个连通分量,所以需要调用两次广度第一次寻找算法。

空间复杂度主要来源于辅助队列。

假如我们访问的1号结点,其他所有结点我们都需要放到辅助队列当中 。(最坏情况)

 

 

因为无向图一共有2E个边(E为vertex顶点的个数)

时间复杂度主要来源于访问各个顶点,遍历各个边。

接下来我们介绍广度优先生成树

 

 我们可修改一下6号结点的邻接结点的访问次序,先访问7后访问3,生成树会有所改变。

由于邻接表的表示方式不唯一,因此基于邻接表的广度优先生成树也不唯一。

 

相近的概念:广度优先生成森林(多个连通分量)

 

 

算法要点:

(1)需要一个辅助队列

(2)如何从一个结点找到与之相邻接的其他顶点

(3)visited数组防止重复访问

(4)如何处理非联通图(在设计一个for循环)

 

6.3.2图的深度优先遍历

我们需要先来复习一下图的深度优先遍历

从遍历结点1到节点2到节点5,没有下一个子树。

 访问结点6,返回上一层循环。

 

 7没有子树会跳出这一层的递归,返回4这一层的递归继续访问4的子树

接下来我们介绍图的深度优先遍历(类似)

 

 从2号结点出发,访问1节点,再从1节点访问5号节点。

由于和5号结点相连的所有节点都被访问过了,所以什么也不会做。

 

就会返回上一层节点的递归调用,就是1号节点这一层。

 

再返回2号节点这一层,之前只访问了一个邻接点,还可以访问邻接顶点6号节点。/

 

 

 和广度优先遍历得到的序列排序还是有区别的。

复杂度分析:

空间复杂度:

最好情况只有两层,只需要递归调用1次。O(1)

 

时间复杂度:

和BFS一样。

 

 

 判断深度优先遍历的序号用邻接表判断简单一些。

 

深度优先生成树:

 

深度优先生成森林:就是非联通的的图所生成的深度优先生成树。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/505626.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Python入门知识】NumPy 中的随机数及ufuncs函数

前言 嗨喽~大家好呀,这里是魔王呐 ❤ ~! 什么是随机数? 随机数并不意味着每次都有不同的数字。随机意味着无法在逻辑上预测的事物。 伪随机和真随机 计算机在程序上工作,程序是权威的指令集。 因此,这意味着必须有某种算法来…

2路 QSFP,40G 光纤的数据实时采集(5GByte/s 带宽)板卡设计原理图 -PCIE732

板卡概述 PCIE732 是一款基于 PCIE 总线架构的高性能数据传输卡,板卡具有 1 个 PCIex8 主机接口、2 个 QSFP40G 光纤接口,可以实现 2 路 QSFP 40G 光纤的数据实时采集、传输。板卡采用 Xilinx 的高性 能 Kintex UltraScale 系列 FPGA 作为实时处理器…

【鲁棒优化、无功优化】两阶段鲁棒优化的主动配电网动态无功优化【IEEE33节点】(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

网曝快手在离职证明上写:如需背调,只能通过公司指定邮箱,其他渠道均不认可!如何捍卫自己的权益?...

许多公司都喜欢用离职证明拿捏打工人,最近有网友曝光快手在离职证明上做文章,在离职证明上写:如需背调,只能通过公司指定邮箱xxxxkuaishou.com,其他渠道均不认可! 楼主问:这种情况如何捍卫自己的…

camunda脚本如何使用

一、camunda脚本有什么用途 在Camunda中,脚本是一种灵活的方式,可以用于在流程定义和表单中编写自定义逻辑。使用脚本,您可以编写JavaScript、Groovy、Python、Ruby等脚本语言中的代码,以实现各种功能。 以下是Camunda脚本的一些…

Shell脚本快速入门

Shell脚本快速入门 1 Hello World2 Shell 变量3 Shell 传递参数4 Shell 基本运算符5 Shell echo命令5 Shell printf 命令6 Shell test 命令7 Shell 流程控制8 Shell 函数9 Shell 输入/输出重定向10 Shell 文件包含参考 1 Hello World 编写脚本文件 test.sh #!/bin/bash echo …

用思科和华为的设备分别完成【单臂路由】的配置

一 什么是单臂路由: 单臂路由(router-on-a-stick)是指在路由器的一个接口上通过配置子接口(或“逻辑接口”,并不存在真正的物理接口)的方式,实现原来相互隔离的不同VLAN(虚拟…

并发编程06:volatile与JMM

文章目录 6.1 被volatile修饰的变量有两大特点6.2 内存屏障(面试重点)6.2.1 生活case6.2.2 是什么6.2.3 内存屏障分类6.2.4 困难内容 6.3 volatile特性6.3.1 保证可见性6.3.2 没有原子性6.3.3 指令禁重排 6.4 如何正确使用volatile6.5 本章最后的小总结6…

运算符重载三大补充(前置后置,操作数与参数顺序,指针参数权限),const修饰成员函数,对>> <<的重载与友元函数声明

TIPS 构造函数析构函数拷贝构造函数运算符重载赋值运算符重载当代码当中的运算符连接的全是内置类型的时候,由于内置类型,它是知道该怎么去进行运算的,所以说会直接转化为指令,然后但凡有一个不是内置类型,而是属于自…

JS 实现区块链添加可视化功能

JS 实现区块链添加可视化功能 学习的最后一部分了,完整的资源在这里:https://download.csdn.net/download/weixin_42938619/87765530,有需求的可以自取。 最后一部分是增加一些可视化的功能,完整实现后如下: HTML 部…

基于yolov7开发构建学生课堂行为检测识别系统

yolov7也是一款非常出众的目标检测模型,在我之前的文章中也有非常详细的教程系列的文章,感兴趣的话可以自行移步阅读即可。 《基于YOLOV7的桥梁基建裂缝检测》 《YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程》 《基于YOLOv7融合…

windows 编译 opencv

编译需要的基础工具 #cmake是配置构建工具,mingw是编译工具 cmake CMake是一款跨平台的编译管理工具,可以自动生成各种不同编译环境(如Makefile、Visual Studio Solution等),从而实现在不同平台上进行代码编译的目的…

PLC与无线开关量测控终端之间Modbus通信实例

本方案是基于Modbus RTU协议下实现的1主多从自组网无线通信形式,主站为S7-1200 PLC,DTD433H作为从站。DTD433H具备输入和输出开关量信号功能,信号传输方向由用户原系统主从设备所实现的功能决定。方案中采用无线开关量信号测控终端DTD433H与欧…

python调用海康sdk报错问题

sdk参考: (68条消息) Python调用海康威视网络相机_调用海康SDK_python 海康威视_有一点点麻瓜的博客-CSDN博客https://blog.csdn.net/yinweizhehd/article/details/118722052 报错1: 生成解决方案的时候,显示LNK2001:无法解析的…

【AI大模型】SparkDesk讯飞星火认知大模型震撼发布,国产AI技术再创新高!

文章目录 前言SparkDesk讯飞星火认知大模型简介语言理解知识问答逻辑推理数学题解答代码理解与编写亲自体验写在最后 前言 5月6日,讯飞星火认知大模型成果发布会在安徽合肥举行。科大讯飞董事长刘庆峰、研究院院长刘聪发布讯飞星火认知大模型,现场实测大…

C++面向对象编程

面向对象编程 面向对象编程和面向过程编程面向过程面向对象 类型设计类的成员函数对象的创建和使用C对象模型this指针构造函数和析构函数构造函数定义和使用析构函数的定义和使用 对象的生存周期拷贝构造函数深拷贝与浅拷贝 运算符的重载 面向对象编程和面向过程编程 面向过程…

设计模式之【适配器模式】,两个人之间确实需要月老的搭线~

文章目录 一、什么是适配器模式1、适配器模式使用场景2、代理、桥接、装饰器、适配器 4 种设计模式的区别3、适配器模式结构 二、类适配器1、实例 三、对象适配器1、实例 四、接口适配器1、实例 五、源码中的应用 一、什么是适配器模式 适配器模式(Adapter Design …

第2天学习Docker——Docker安装

一、前言 Docker 是一个用于开发、传送和运行应用程序的开放平台。Docker 使您能够将应用程序与基础设施分开,以便您可以快速交付软件。使用 Docker,您可以像管理应用程序一样管理基础设施。通过利用 Docker 的快速交付、测试和部署代码的方法&#xff0…

vue3学习一 setup

vue3中没有 data 等配置项, 并且它的引入方式也不是像vue2中的 import vue就可以了, 而是用到什么再引入什么, 其中 setup() 函数, 是最大的区别 vue3中的 setup 有点像vue2中的 data , 但又不完全是 setup 会在 生命周期create…

关于C语言

C99是啥 很多书籍开篇会突然提到C99标准,因此这里搜了一下。 C99是C语言的官方标准第二版。1999年12月1日,国际标准化组织和国际电工委员会旗下的C语言标准委员会正式发布了这个标准文件 ; C99是在C89和C90的基础上发展起来的,增加…