算法——图——bsf 广度优先搜索算法 (Breadth First Search)

图遍历算法——bsf 广度优先搜索算法 (Breadth First Search) 算法

  • 概述
  • 算法过程
    • 步骤一:初始化原点到队列
    • 步骤二:将队列的头顶点放入到已完成集合
    • 步骤三:将订单的关联顶点放入到队列中
    • 步骤四:将u顶点设置为完成节点。
    • 步骤五:重复步骤二至四。
  • 时间复杂度&空间复杂度
    • 时间复杂度
    • 空间复杂度

概述

        广度优先搜索(BFS)是一种重要的图遍历算法,用于在横向运动中搜索图的所有顶点。它从一个给定的顶点开始,在进入下一个级别之前访问它的所有邻居。BFS的时间复杂度取决于图中顶点和边的数量。

文章中使用的动画网站地址:
限 pc: 广度优先算法 :http://www.donghuasuanfa.com/platform/portal?pc=bfs

算法一览表:https://blog.csdn.net/ww753951/article/details/106862328

动画算法一览表:http://www.donghuasuanfa.com/portal

算法过程

        算法分为五个步骤。
        步骤一:将源点放入到队列中。
        步骤二:将队列的头顶点u放入到已完成列表。
        步骤三:将u的所有未处理过的关联顶点放入到队列中,并标记为已处理。

        步骤四:将u顶点设置为完成顶点。
        步骤五:重复步骤二至四。


以下图为例,图的原点为7,则算法遍历图节点的顺序为7,13,25,16,18,39。

请添加图片描述

步骤一:初始化原点到队列

步骤演示过程如下图1-1所示。节点7为源点。算法首先将节点7移动到队列Q中。

请添加图片描述

图1-1

步骤二:将队列的头顶点放入到已完成集合

将队列的头元素u放入到已遍历完成列表。当前队列的头部顶点为7,所以将7顶点移动到已遍历集合。步骤演示过程如下图2-1所示。
请添加图片描述

图2-1

步骤三:将订单的关联顶点放入到队列中

将u的所有未处理过的关联顶点放入到队列中,并标记为已处理,节点颜色变为红色。
当前u的所有未处理的元素分别为13,25,16。所以将7的关联顶点分别放入队列。
步骤演示过程如下图3-1所示。

请添加图片描述

图3-1

步骤四:将u顶点设置为完成节点。

当前顶点为u=7。 将u=7顶点设置为已完成,并标记为绿色。步骤演示过程如下图3-1所示。
请添加图片描述

图4-1

步骤五:重复步骤二至四。

步骤二:将队列的头部顶点13放入到已遍历结合。
步骤三:将13节点的关联元素放入到到队列, 因为13的关联顶点分别为7和25,且7已处理、25已放入队列,所以13顶点的此步骤无需处理。
步骤四:将13节点设置为完成节点。
整体步骤如图5-1所示。

请添加图片描述

图5-1





        剩下的节点处理和上述步骤一致,不再赘述。

时间复杂度&空间复杂度

时间复杂度

        在BFS中,每个顶点和边只访问一次。因此,BFS的时间复杂度可以表示为O(V+E),其中V是图中顶点的数量,E是图中边的数量。

        让我们分解一下时间复杂性分析:
        1.访问所有顶点:BFS需要访问图中的所有顶点。这需要O(V)时间。
        2.检查所有边:BFS还需要检查所有边,以确定是否有任何未访问的顶点连接到当前顶点。对于每个顶点,我们需要检查其所有相邻顶点。在最坏的情况下,每个顶点与其他每个顶点都有一条边,即一个完整的图。这需要O(E)时间。

因此,BFS的总体时间复杂度为O(V+E)。

空间复杂度

        BFS的空间复杂度由队列数据结构决定,队列数据结构用于跟踪访问的顶点和要探索的顶点。在最坏的情况下,当访问所有顶点时,队列可以将所有顶点存储在图的一个级别上。因此,BFS的空间复杂度也是O(V)。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录算法训练营第23期day49| 123.买卖股票的最佳时机III、188.买卖股票的最佳时机IV

目录 一、(leetcode 123)买卖股票的最佳时机III 二、(leetcode 188)买卖股票的最佳时机IV 一、(leetcode 123)买卖股票的最佳时机III 力扣题目链接 增加了两次的限制,相应的就是需要考虑的状…

【正点原子STM32连载】 第五十章 FATFS实验 摘自【正点原子】APM32F407最小系统板使用指南

1)实验平台:正点原子stm32f103战舰开发板V4 2)平台购买地址:https://detail.tmall.com/item.htm?id609294757420 3)全套实验源码手册视频下载地址: http://www.openedv.com/thread-340252-1-1.html## 第五…

解决@Autowired警告

一.前言 再使用springboot自动注入Autowired注解时,下方会出现波浪线警告,这是什么原因呢?我们细看提示说明已经说的很清楚了,Field injection is not recommended “不建议使用字段注入”,字段注入是指通过直接将依赖项注入到类的字段中来实现依赖注入。这种方式存在一些问题…

Lightroom Classic 2023 v12.4

Lightroom Classic 2023是一款图像处理软件,是数字摄影后期制作的重要工具之一。与其他图像处理软件相比,Lightroom Classic具有以下特点: 高效的图像管理:Lightroom Classic提供了强大的图像管理功能,可以轻松导入、…

Unit3:贪心算法

文章目录 一、介绍二、分数背包问题问题描述分析时间复杂度伪代码案例彩蛋 三、活动选择问题问题描述分析伪代码时间复杂度拓展:加权活动选择分析计算伪代码时间复杂度案例 对比动态规划和贪心算法 四、哈夫曼编码分类定长编码 目标变长码 案例分析伪代码时间复杂度…

halcon获取轮廓属性的时候报错:Contour attribute not defined(HALCON错误代码:3261)

报错截图: 在使用以下算子,获取xld的distance属性时,或者其他属性时报错。 get_contour_attrib_xld (ObjectSelected, distance, Attrib) 如果是属性报错。这里需要在调用获取轮廓属性之前先获得轮廓之间的距离。 使用以下算子:…

设置专属链接的这些作用你知道吗?

专属链接作为一种个性化的链接,用于为特定的客户或群体提供定制化的体验或服务。对于企业来说,每个渠道或者每个客户都能拥有一个专属链接是无比便利的事情。企业可以将这个链接嵌入到各种宣传物料中,让客户通过输入链接即可进入与客服的交流…

壁灯外贸出口的UL1598检测标准解析

壁灯是安装在室内墙壁上的辅助照明装饰灯具,一般多配用乳白色的玻璃灯罩。灯泡功率多在15-40瓦左右,光线淡雅和谐,可把环境点缀得优雅、富丽,尤以新婚居室特别适合。壁灯的种类和样式较多,一般常见的吸顶灯、变色壁灯、…

红队专题-从零开始VC++C/S远程控制软件RAT-MFC-超级终端

红队专题 招募六边形战士队员[16]超级终端(1) 招募六边形战士队员 一起学习 代码审计、安全开发、web攻防、逆向等。。。 私信联系 [16]超级终端(1) 服务端 — 本地打开cmd — 接收命令 — 执行 — 发送回显 客户端 — 远端发送命令 — 接收回显 发送开启cmd命令 --- 接受…

vue-组件注册及使用

​🌈个人主页:前端青山 🔥系列专栏:Vue篇 🔖人终将被年少不可得之物困其一生 依旧青山,本期给大家带来vue篇专栏内容-组件注册及使用 目录 1、组件的注册及使用 2、组件常用属性 2.1、directive 2.2、computed 2.…

GoLong的学习之路,进阶,语法之并发(并发错误处理)补充并发三部曲

这篇文章主要讲的是如何去处理并发的错误。 在Go语言中十分便捷地开启goroutine去并发地执行任务,但是如何有效的处理并发过程中的错误则是一个很棘手的问题。 文章目录 recovererrgroup recover 哦对,似乎没写错误处理的文章。后面补上。 首先&…

低功耗蓝牙技术 > GAP和GATT介绍

GAP(Generic Access Profile)和GATT(Generic Attribute Profile)简介 在蓝牙技术的发展中,GAP和GATT两个协议扮演着关键的角色,为BLE(低功耗蓝牙)设备之间的通信提供了规范和框架。…

IPSec案例部署

项目拓扑与项目求 项目需求 某企业网络使用ospf作为IGP协议实现内部网络的互联互通,区域规划和IP规划如图所示,现在要求实现如下需求: 公司总部和分支之间互访,使用IPSec VPN传递流量,并且对其加密,公司内…

IntellJ IDEA利用spring initializr创建springboot项目

maven仓库修改镜像源 idea会默认从.m2目录下读取maven配置信息&#xff0c;若没有setting.xml则从maven安装目录拷贝一个setting.xml到这里 在xml中添加阿里云镜像源 <mirrors><mirror> <id>nexus-aliyun</id> <name>nexus-aliyu…

鸿蒙原生应用开发-DevEco Studio中HarmonyOS与OpenHarmony项目的切换

一、找到该目录 二、修改操作系统类型 三、分别进行开发&#xff0c;一些常规的应用功能实现后&#xff0c;相互切换后都可以正常运行的。前期OpenHarmony项目如果连接开发板比较困难的化&#xff0c;开发完成后&#xff0c;切换成为HarmonyOS后就可以比较详细地看看效果了。

FNPLicensingService.exe 总提示要联网

目录预览 一、问题描述二、原因分析三、解决方案&#xff1a;四、参考链接 一、问题描述 FNPLicensingService.exe 总提示要联网 找到路径如下&#xff1a; C:\Program Files (x86)\Common Files\Macrovision Shared\FlexNet Publisher然而从文件目录来看&#xff0c;并没有…

智能电网线路阻抗模拟负载的工作原理

智能电网线路阻抗模拟负载是一种用于测试和评估电网线路性能的技术&#xff0c;它的工作原理是通过模拟负载来模拟实际负载对电网的影响&#xff0c;以便评估电网的稳定性和可靠性&#xff0c;智能电网线路阻抗模拟负载通常由电子设备和控制系统组成。电子设备主要包括电阻、电…

OLED透明屏在智慧零售场景的应用

OLED透明屏在智慧零售场景中的应用主要包括以下几个方面&#xff1a; 商品展示&#xff1a;OLED透明屏可以作为商品展示窗口&#xff0c;使得产品可以在玻璃的透明表面上直接呈现展示&#xff0c;同时显示相关的文字和视频广告信息。这种宣传模式可以更加吸引顾客注意力&#…

高性能图表库LightningChart JS v5.0 - 轻松实现图表自定义布局

LightningChart JS是Web上性能最高的图表库具有出色的执行性能 - 使用高数据速率同时监控数十个数据源。 GPU加速和WebGL渲染确保您的设备的图形处理器得到有效利用&#xff0c;从而实现高刷新率和流畅的动画。 点击获取LightningChart JS v5.0正式版下载 LightningChart JS …

瑞吉外卖Day03

小张推荐:瑞吉外卖Day02 1.启用/禁用员工账号 1.1 思路分析 1.2Controller层 PutMapping()public R<String> update(RequestBody Employee employee, HttpServletRequest request) {log.info(employee.toString());Long emp (Long) request.getSession().getAttribu…