【优选算法专栏】专题十六:BFS解决最短路问题---前言

本专栏内容为:算法学习专栏,分为优选算法专栏,贪心算法专栏,动态规划专栏以及递归,搜索与回溯算法专栏四部分。 通过本专栏的深入学习,你可以了解并掌握算法。
💓博主csdn个人主页:小小unicorn

⏩专栏分类:算法从入门到精通

🚚代码仓库:小小unicorn的代码仓库🚚

🌹🌹🌹关注我带你学习编程知识

专题十六

什么是最短路问题:

我们先举一个例子:

A是起点,I是终点。我们从A到I有以上好多种路径,并且点与点之间的距离是一样的,上面例子距离都为1.而这个距离我们也把它叫做边权。

我们此专题就解决的是边权为1的最短路问题,同时我们也可以解决边权相同的最短路问题。

两者是同类型题目。

如何解决最短路问题

那么介绍了什么是最短路问题,那么我们如何解决它呢?

其实很简单:
我们从起点开始,进行一次BFS即可

那么肯定首先需要一个队列来存储信息,其次我们还需要一个数组,可以是一个bool数组也可以是哈希表,其目的都是用来标记当前位置是否已经被遍历过了。

接下来我们模拟一下这个过程:

从 A A A到 I I I:

先把 A A A这个点扔到队列里面,丢进队列后进行标记,弹出对头元素,

把对头元素能去到地方加入到队列里面,从 A A A可以到达 B B B和 C C C,将 B B B和 C C C丢进队列,相当于在 A A A基础上向外扩展一层,然后统计队列里面有多少个元素,同时讲这些元素弹出去(在循环里)然后再同时向外扩展,依次内推...

当走到 I I I位置时,走到终点。最短路我们也就找到了。

最短路径我们知道是那一条,那么这个最短路是多少呢?

其实不难发现,我们层序遍历是一层一层剥开,那么这个扩展的层数其实就是我们的最短路的长度。

介绍到这,我们的最短路就基本介绍差不多了,其实就是用BFS来进行寻找最短路径。

相关推荐
头发够用的程序员39 分钟前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此1 小时前
【数据清洗缺失值处理】
python·算法·数学建模
Halo_tjn2 小时前
Java 基于字符串相关知识点
java·开发语言·算法
念越2 小时前
算法每日一题 Day08|双指针法解决三数之和
算法·力扣
黎阳之光2 小时前
黎阳之光透明管理:视频孪生重构智慧仓储新范式
人工智能·算法·安全·重构·数字孪生
CappuccinoRose3 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦3 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw
Robot_Nav4 小时前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi
小O的算法实验室5 小时前
2026年ESWA,自适应基于排序的协同进化学习粒子群算法+边缘计算服务器部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
cpp_25015 小时前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp