【JavaScript 算法】广度优先搜索:层层推进的搜索策略

在这里插入图片描述

🔥 个人主页:空白诗

在这里插入图片描述

文章目录

    • 一、算法原理
    • 二、算法实现
    • 三、应用场景
    • 四、优化与扩展
    • 五、总结

在这里插入图片描述

广度优先搜索(Breadth-First Search, BFS)是一种用于遍历或搜索图或树数据结构的算法。该算法从起始节点开始,逐层向外扩展,直到找到目标节点或遍历完所有节点。本文将详细介绍广度优先搜索算法的原理、实现及其应用。


一、算法原理

广度优先搜索的基本思想是从起始节点开始,先访问所有相邻节点,然后再依次访问这些相邻节点的相邻节点,以此类推,层层推进。其基本步骤如下:

  1. 从起始节点开始,将其标记为已访问,并加入队列。
  2. 当队列不为空时,取出队列的头节点,访问该节点的所有相邻节点。
  3. 对于每个相邻节点,如果未被访问过,将其标记为已访问并加入队列。
  4. 重复步骤2和3,直到队列为空或找到目标节点。

在这里插入图片描述


二、算法实现

以下是广度优先搜索的JavaScript实现:

/*** 广度优先搜索算法* @param {Object} graph - 图的邻接表表示* @param {string} start - 起始节点*/
function breadthFirstSearch(graph, start) {const queue = [start]; // 初始化队列,将起始节点加入队列const visited = new Set(); // 用于记录已访问的节点visited.add(start); // 将起始节点标记为已访问while (queue.length > 0) {const node = queue.shift(); // 取出队列的头节点console.log(node); // 访问节点// 访问当前节点的所有相邻节点for (const neighbor of graph[node]) {// 如果相邻节点未被访问过,将其标记为已访问并加入队列if (!visited.has(neighbor)) {visited.add(neighbor);queue.push(neighbor);}}}
}// 示例图的邻接表表示
const graph = {A: ['B', 'C'],B: ['D', 'E'],C: ['F'],D: [],E: ['F'],F: []
};// 调用广度优先搜索算法
breadthFirstSearch(graph, 'A'); // 输出: A B C D E F
  1. 函数定义与参数

    • breadthFirstSearch(graph, start):广度优先搜索算法,接受图的邻接表表示和起始节点作为参数。
  2. 初始化队列和已访问节点集合

    • const queue = [start];:初始化队列,将起始节点加入队列。
    • const visited = new Set();:初始化已访问节点集合,用于记录已访问的节点。
  3. 标记起始节点为已访问

    • visited.add(start);:将起始节点标记为已访问。
  4. 遍历队列中的节点

    • while (queue.length > 0):当队列不为空时,继续遍历。
    • const node = queue.shift();:取出队列的头节点。
  5. 访问节点并访问其相邻节点

    • console.log(node);:访问节点,打印节点值。
    • for (const neighbor of graph[node]):遍历当前节点的相邻节点。
    • if (!visited.has(neighbor)):如果相邻节点未被访问过。
    • visited.add(neighbor);:将相邻节点标记为已访问。
    • queue.push(neighbor);:将相邻节点加入队列,等待后续遍历。
  6. 示例图和调用

    • 定义一个示例图的邻接表表示。
    • 调用breadthFirstSearch函数,进行广度优先搜索,并输出结果。

三、应用场景

  1. 最短路径搜索
    广度优先搜索可以用于在无权图中寻找两个节点之间的最短路径。由于BFS逐层遍历,第一次找到目标节点时,即可保证路径是最短的。

  2. 连通性检查
    BFS可以用于检查图的连通性,确定图中是否存在路径连接所有节点,并找出所有连通分量。

  3. 层次遍历
    BFS在树的层次遍历中有重要应用,可以按层次顺序访问树的节点。

  4. 求解迷宫问题
    在迷宫问题中,BFS可以用于寻找从起点到终点的最短路径,通过逐层扩展,可以找到最短路径解。


四、优化与扩展

  1. 记录路径
    在实际应用中,除了访问节点外,还需要记录从起始节点到每个节点的路径,可以通过在队列中存储路径信息来实现。
/*** 广度优先搜索算法(记录路径)* @param {Object} graph - 图的邻接表表示* @param {string} start - 起始节点* @return {Object} - 每个节点的路径*/
function breadthFirstSearchWithPath(graph, start) {const queue = [[start]]; // 初始化队列,队列中存储路径const visited = new Set(); // 用于记录已访问的节点visited.add(start); // 将起始节点标记为已访问while (queue.length > 0) {const path = queue.shift(); // 取出队列的头路径const node = path[path.length - 1]; // 获取路径中的最后一个节点console.log(node); // 访问节点// 访问当前节点的所有相邻节点for (const neighbor of graph[node]) {// 如果相邻节点未被访问过,将其标记为已访问并加入队列if (!visited.has(neighbor)) {visited.add(neighbor);const newPath = [...path, neighbor]; // 创建新的路径queue.push(newPath); // 将新路径加入队列}}}
}// 调用广度优先搜索算法(记录路径)
breadthFirstSearchWithPath(graph, 'A');
  1. 双向广度优先搜索
    对于某些特殊场景,可以使用双向广度优先搜索,同时从起点和终点开始进行BFS,直到两边相遇,从而减少搜索空间,提高效率。

五、总结

广度优先搜索(BFS)是一种用于遍历或搜索图或树数据结构的有效算法。它通过逐层推进的方式,从起始节点开始,先访问所有相邻节点,然后再依次访问这些相邻节点的相邻节点,以此类推,直到找到目标节点或遍历完所有节点。广度优先搜索算法实现简单,适用于最短路径搜索、连通性检查、层次遍历和求解迷宫问题等应用场景。


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

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

相关文章

小程序-2(WXML数据模板+WXSS模板样式+网络数据请求)

目录 1.WXML数据模板 数据绑定 事件绑定 小程序中常用的事件 事件对象的属性列表 target和currentTarget的区别 bindtap的语法格式 在事件处理事件中为data中的数据赋值 事件传参与数据同步 事件传参 bindinput的语法绑定事件 文本框和data的数据同步 条件渲染 w…

SpringCloud | 单体商城项目拆分(微服务)

为什么要进行微服务拆分? 在平常的商城项目中,我们一般的项目结构模块都是将各种业务放在同一个项目文件夹,比如像: 用户,购物车,商品,订单,支付等业务都是放在一起,这样…

线上观看 3 万+!「智能运维MeetUp」精彩回顾,探讨智能体构建新方向

龙蜥社区“走进系列”第 11 期走进中兴通讯-智能可观测运维技术 MeetUp 于成都圆满结束,由中兴通讯联合龙蜥社区系统运维联盟(SOMA)(以下简称“联盟”)共同举办。本次活动现场汇聚了阿里云、谐云科技、乘云数字、中兴通…

MySQL数据库day7.11

一,SQL概述 1.1 SQL语句语法 MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写, 以分号结尾。例如: SELECT * FROM user; 使用 /**/ 、 -- 、 # 的方式完成注释 /* 多行注释 */ -- 单行注释 # 单行注释 SELECT * FRO…

计算机硬件---如何更新自己电脑的BLOS

1找官网 例如“我使用的是HP(惠普)品牌的电脑”我只需要在浏览器上搜索“惠普官网”或“惠普-blos更新” 就可以看到,来自官网中更新blos的信息 2.有些品牌要查序列号该怎么办呢? 有许多方法可以查询,例如&#xf…

android13 frameworks里面常用的保存信息或者版本判断的方法

总纲 android13 rom 开发总纲说明 目录 1.前言 2. 数据库 2.1 代码读取用法参考 3.prop 属性配置 3.1 property的key值有哪些特点 4.区别 5. 其他数据存储 6.彩蛋 1.前言 frameworks 不像我们一般开发app那样,很多应用保存的方法都无法使用。这里记录我们系统rom开…

关于java的反射

❓❓❓反射是啥呀相信许多学java的同学非常困惑在学的时候,总是感觉懂了却又没懂或者直接忽略过去了,那么本文就带大家探讨一下什么是反射在java中以及它的机制和运用。 ⭐️什么是反射: 首先我们知道一些知识: 维基百科的解释 …

springboot项目 导入 maven坐标 错误 Could not transfer artifact XXX

1.报错原因 当时导入的是 redis坐标 ,导入jar 包报错(当时是网速太慢了,一直卡着不动 就关了 idea 重新下载)结果报错 之前的redis 项目都可以的,网上找了一下 都没解决 2.解决办法 既然说不能传输, 就说…

有用的工具

一、appuploader Appuploader home -- A tool improve ios develop efficiency such as submit ipa to appstore and manage ios certificate这是一款p12证书查看的工具, 需要建立一个apple ID专用密码:Manage your Apple ID

redis其他类型和配置文件

很多博客只讲了五大基本类型,确实,是最常用的,而且百分之九十的程序员对于Redis只限于了解String这种最常用的。但是我个人认为,既然Redis官方提供了其他的数据类型,肯定是有相应的考量的,在某些特殊的业务…

C++相关概念和易错语法(22)(final、纯虚函数、继承多态难点)

1.final final在继承和多态中都可以使用,在继承中是指不想将自己被继承,在多态中是指不想该函数被重写,比较简单,下面是一些使用例子。 2.纯虚函数 当我们需要抽象一个类的时候,我们就需要用到纯虚函数。所谓抽象的类…

如何设计统计量及相关假设检验

一、如何设置H0和H1假设 谁做H0,谁做H1,在统计学的假设检验里是有约定俗成的规定的。即:status quo(默认/现状)是H0,而新观点或试图challenge现状的是H1。H1也叫research hypothesis,所以我们做…

【多个Python版本存在,使用pip+不同版本安装库时,windows弹出打开方式窗口的解决方法】

问题描述 电脑上存在python3.9,3.10,3.11,安装顺序也是先安装3.9,然后3.10,最后3.11,那么直接使用pip安装,会装在3.11的位置,经过搜索可以通过pip版本,比如pip3.9 insta…

如何在勒索软件攻击中幸存下来:最佳备份实践、勒索拦截方案

无论身处什么业务或行业,数据都是您业务的关键资产。没有针对数据进行安全可靠的备份保护,您将会受到许多“可能性”的威胁,无论数据丢失是由于在键盘上洒了饮料还是遭受到了勒索软件的攻击。 为了确保业务不被中断,企业数据不会…

Python: 初识Python

文章目录 1. Python的背景知识1.1 Python是咋来的?1.2 Python的特点1.3 Python能干啥?1.4 Python的缺点 2. 搭建Python环境2.1 安装Python2.2 安装PyCharm2.3 用pycharm编写python程序 1. Python的背景知识 1.1 Python是咋来的? 由Guido van Rossum于1989年圣诞节为打发无…

一个用于管理多个 Node.js 版本的安装和切换开源工具

大家好,今天给大家分享一个用于管理多个Node.js版本的工具 NVM(Node Version Manager),它允许开发者在同一台机器上安装和使用不同版本的Node.js,解决了版本兼容性问题,为开发者提供了极大的便利。 在开发环…

路网双线合并单线——ArcGISpro 解决方法

路网双线合并成单线是一个在地图制作、交通规划以及GIS分析中常见的需求。双线路网定义:具有不同流向、不同平面结构的道路。此外,车道数较多的道路(例如,双黄实线车道数大于4的道路)也可以视为双线路网,本…

iPhone 如何修改锁屏密码?修改密码的具体步骤总结

修改 iPhone 锁屏密码 当你还记得当前设置的锁屏密码时,想要修改密码就非常的简单了,只需要简单的点几下就可以重新设置新密码,下面是具体的操作步骤: 首先我们进入设置应用程序,然后找到“面容 ID 与密码”。 然后需…

(01)Unity使用在线AI大模型(使用百度千帆服务)

目录 一、概要 二、环境说明 三、申请百度千帆Key 四、使用千帆大模型 四、给大模型套壳 一、概要 在Unity中使用在线大模型分为两篇发布,此篇文档为在Python中使用千帆大模型,整体实现逻辑是:在Python中接入大模型—>发布为可传参的…

护眼台灯的功能作用有哪些?深挖台灯护眼是真的吗

随着现代生活方式的改变,孩子们面临着越来越多的视力挑战。在近视学生中,近10%为高度近视,且占比随年级升高而增长。幼儿园6岁儿童中有1.5%为高度近视,而高中阶段则达到了17.6%。为了守护孩子们的视力健康,在科技飞速发…