【详细整理】广度优先算法
目录标题
- 一、模板
- 一、 理论
- 1、解决的问题
- 2、实现方法
- 3、补充:队列的理论知识
一、模板
// bfs,最常用于最小路径问题Queue<> queue = new LinkedList<>();// 这里是假设元素不会重复,所以用Set来判断一个元素是否已经读取过Set<> visited = new Set<>();queue.offer(起点);visited.add(起点);int step = 0;while (!queue.isEmpty()) {int size = queue.size();while (size > 0) {Node node = queue.poll();// 判断是否是终点if(终点满足的条件){return step;}// 不是终点,将这个点的邻域点放入队列for(Node x : node所连接的节点){if(x not in visited ){queue.offer(x);visited.add(x); }}}// step++放在这个位置是因为bfs是一层层往外推进,走完一层之后再++step++;
以上是BFS的通用框架。
一、 理论
1、解决的问题
广度优先搜索可回答两类问题:
第一类问题:从节点A出发,有前往节点B的路径吗?
第二类问题:从节点A出发,前往节点B的哪条路径最短?
2、实现方法
在广度优先搜索的执行过程中,搜索范围从起点开始逐渐向外延伸,即先遍历搜索第一层临近关系(跟目标节点直接相连的节点,路径长度为1),再遍历搜索第二层临近关系(路径长度为2),直到找到目标
↑
只有按添加顺序查找,才可实现先检查一层关系,再检查二层关系
↑
先进先出:队列实现
同时,为了避免添加过的元素反复添加,进入死循环,需要用Set、List等来记录添加过的元素
3、补充:队列的理论知识
因为队列只允许在一端插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出
一个是队头指针front,它指向队头元素;另一个是队尾指针rear,它指向下一个入队元素的存储位置
每次在队尾插入一个元素是,rear增1;每次在队头删除一个元素时,front增1。
1) "下溢"现象:当队列为空时,做出队运算产生的溢出现象。“下溢”是正常现象,常用作程序控制转移的条件。
(2)"真上溢"现象:当队列满时,做进栈运算产生空间溢出的现象。“真上溢”是一种出错状态,应设法避免。
(3)"假上溢"现象:由于入队和出队操作中,头尾指针只增加不减小,致使被删元素的空间永远无法重新利用。当队列中实际的元素个数远远小于向量空间的规模时,也可能由于尾指针已超越向量空间的上界而不能做入队操作。该现象称为"假上溢"现象。
无论插入或删除,一旦rear指针增1或front指针增1 时超出了所分配的队列空间,就让它指向这片连续空间的起始位置(循环队列)
在循环队列中,当队列为空时,有front=rear,而当所有队列空间全占满时,也有front=rear。为了区别这两种情况,规定循环队列最多只能有MaxSize-1个队列元素,当循环队列中只剩下一个空存储单元时,队列就已经满了。因此,队列判空的条件时front=rear,而队列判满的条件时front=(rear+1)%MaxSize
【详细整理】广度优先算法相关推荐
- 机器学习【期末复习总结】——知识点和算法例题(详细整理)
机器学习[期末复习总结]--知识点和算法例题(详细整理) 1.什么是机器学习,什么是训练集,验证集和测试集?(摘自ML科普系列(一)) 机器学习: 对计算机一部分数据进行学习,然后对另外一些数据进行预 ...
- python爬虫算法深度优先_爬虫课程(四)|深度优先和广度优先算法
深度优先和广度优先算法在爬取一个整站上经常用到,本课程主要讲解这两个算法的原理以及使用过程. 一.网站的树结构 1.1.一个网站的url结构图 以知乎为例,知乎目前有发现.话题.Live.书店.圆桌. ...
- (造轮子)C 创建队列和图实现广度优先算法(BFS)和深度优先算法(DFS)(数据结构)
链表.队列和图实现BFS和DFS算法(C+造轮子+详细代码注释) 1.队列的链式存储结构 队列的链式表示称为链队列,它实际上是一个同时带有队头指针和队尾指针的单链表.头指针指向队头节点,尾指针指向 ...
- 机器学习需要掌握的数学知识点---详细整理
机器学习需要掌握的数学知识点---详细整理 第一篇 线性代数篇 第一章 排队!排队!什么是向量 第二章 矩阵 第三章 距离 第二篇 概率偏 由暗恋引发的思考 机器学习中的概率研究 贝叶斯问题 第三篇 ...
- stm32正常运行流程图_STM32单片机学习笔记(超详细整理143个问题,学习必看)...
原标题:STM32单片机学习笔记(超详细整理143个问题,学习必看) 1.AHB系统总线分为APB1(36MHz)和APB2(72MHz),其中2>1,意思是APB2接高速设备 2.Stm32f ...
- 计算机网络面试题-(较详细整理版)
计算机网络 计算机网络体系结构 计算机网络的体系结构 应用层 应用层是为了特定的应用程序提供数据传输服务. 关键词:特定,应用程序.例如为万维网需要遵循HTTP协议,文件传输需要遵循FTP协议,域名解 ...
- 广度优先算法(BFS)入門理解
简介 广度优先算法(BFS)和深度优先算法(DFS)是图这种数据结构最基础的算法,所以需要我们花心思去学习.能知道BFS和DFS这个名词就证明同学们已经在书上看到了他们的介绍.不过对于初入门的同学来说 ...
- 广度优先算法和深度优先算法-树形结构(层级结构)-Java
广度优先算法和深度优先算法-树形结构(层级结构)-Java 目录 文章目录 1.前言 2.递归 3.栈+深度优先算法 4.队列+广度优先算法 5.比较 ***后记*** : 内容 1.前言 在日常应用 ...
- 深度广度优先算法、A*算法
深度广度优先算法.A*算法 深度优先算法(DFS) 实现步骤 实现代码 广度优先算法(BFS) 实现步骤 实现代码 A*算法 Dijkstra算法 A*算法介绍 实现流程 实现过程 实现代码 深度优先 ...
- 浅谈网络爬虫中广度优先算法和代码实现
前几天给大家分享了网络爬虫中深度优先算法的介绍及其代码实现过程,没来得及上车的小伙伴们可以戳这篇文章--浅谈网络爬虫中深度优先算法和简单代码实现.今天小编给大家分享网络爬虫中广度优先算法的介绍及其代码 ...
最新文章
- python3 练习3
- php之自动加载(懒加载)
- h264检测是I帧还是P帧
- php system startup,opencart Warning: require_once(/system/startup.php) failed to open stream
- 30-10-010-编译-kylin-on-druid-2.6.0-CDH57编译
- JavaScript的DOM编程--01--js代码的写入位置
- docker上安装nginx服务
- 安装74cms时出现的错误
- 查询各科成绩的前三名的学生
- 泰坦尼克号各种因素对存活率的影响
- 第五章. 可视化数据分析图表—常用图表的绘制2—直方图,饼形图
- STM32F103定时器详解
- Windows系统自带录屏功能,再也不用下录屏软件了
- linux如何查看无线密码是多少个,在 Linux 中查看连接过的 WiFi 密码
- cvs提交错误:'Committing resources' has encountered a problem 解决办法-------程序员没有解决不了的错误
- 软件测试 —— Python学习路线
- ios10.2重新安装cydia(包含恢复数据库)
- SIwave仿真手册——信号完整性仿真之背钻、模型添加、HFSS求解区域的划分(三)
- 最新版本 JDK 下载体验
- 软件测试人员到底需不需要懂代码,我来告诉你