算法——图——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)。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习samba

文章目录 一、samba介绍二、samba的主要进程三、配置文件四、例子 一、samba介绍 1、SMB(Server Message Block)协议实现文件共享,也称为CIFS(Common Internet File System)。 2、是Windows和类Unix系统之间共享文件的…

主题讲座:全球增材制造现状与未来(暨香港科技大学广州|智能制造学域2024博士学位全额奖学金项目)

时间:2023 年11月16日(星期四)14:30 地点:合肥工业大学 学术会议中心三楼报告厅 主讲嘉宾:陈模军 助理教授 https://facultyprofiles.hkust-gz.edu.cn/faculty-personal-page/CHEN-Mojun/mjchen 报名表直达&#xff1…

Ubuntu 和 Windows 文件互传

FTP 服务 FTP 采用 Internet 标准文件传输协议 FTP 的用户界面, 向用户提供了一组用来管理计算机之间文件传输的应用程序。在开发的过程中会频繁的在 Windows 和 Ubuntu 下进行文件传输,比如在 Windwos 下进行代码编写,然后将编写好的代码拿到…

C语言--每日五道选择题--Day9

第一题 1、如下程序的运行结果是( ) char c[5]{a, b, \0, c, \0}; printf("%s", c); A: a b B: ab\0c\0 C: ab c D: ab 答案及解析 D 首先这是一个字符数组,我们要知道无论是字符串还是字符数组,它们遇到ASCII值为0就…

分布式锁介绍

为什么需要分布式锁 在单机部署的系统中,使用线程锁来解决高并发的问题,多线程访问共享变量的问题达到数据一致性,如使用synchornized、ReentrantLock等。 但是在后端集群部署的系统中,程序在不同的JVM虚拟机中运行,且…

人工智能与充电技术:携手共创智能充电新时代

人工智能与充电技术:携手共创智能充电新时代 摘要:本文探讨了人工智能与充电技术的结合及其在未来充电设施领域的应用。通过分析智能充电系统的技术原理、优势以及挑战,本文展望了由人工智能驱动的充电技术为未来电动交通带来的巨大变革与机…

理解快速排序

理解快速排序 首先了解以下快速排序 快速排序(QuickSort)是一种常用的排序算法,属于比较排序算法的一种。它是由英国计算机科学家Tony Hoare于1960年提出的,是一种分而治之(divide and conquer)的算法。 …

基础课1——智能客服的定义

1.介绍 智能客服是一种采用人工智能技术的客户服务方式,它通过语音识别、自然语言处理、语义理解等技术,实现了与客户的自动交互。智能客服可以提供客户24小时不间断的服务,帮助客户快速解决问题,提高客户满意度。智能客服的应用…

vue day1(主要是指令)

1、引包 或者:cdn网址 2、创建实例,初始化渲染 3、插值表达式 {{}} 表达式:可以被求值的代码 4、响应式数据:数据发生变化,视图自动更新(底层是dom操作) data中数据会被添加到实例上&#x…

vue:如何把后端传过来的数组的其中一个对象加入新的属性

加入我们是更改数组中的第一个对象&#xff0c;在vue中可以使用$set方法将属性插入到第一个对象中作为属性。 Script部分&#xff1a; <script>export default {data() {return {boxes: [//模拟后端传过来的数组{id:1,name:张三},{id:2,name:李四},{id:3,name:王五},{i…

【Linux】Centos7 shell实现MySQL5.7 tar 一键安装

&#x1f984; 个人主页——&#x1f390;个人主页 &#x1f390;✨&#x1f341; &#x1fa81;&#x1f341;&#x1fa81;&#x1f341;&#x1fa81;&#x1f341;&#x1fa81;&#x1f341; 感谢点赞和关注 &#xff0c;每天进步一点点&#xff01;加油&#xff01;&…

NFS服务器的搭建

架设一台NFS服务器&#xff0c;并按照以下要求配置 准备阶段&#xff1a;准备两台虚拟机&#xff0c;一台作为服务端&#xff0c;一台作为客户端 服务端&#xff08;Server&#xff09;&#xff1a;192.168.75.139 客户端&#xff08;Client&#xff09;:192.168.75.160 两…