图的最短路径算法-迪杰斯特拉(Dijkstra)算法与弗洛伊德(Frolyd)算法(更新中)

一、最短路径算法(Shortest Path)

最短路径问题是图论研究中的一个经典算法问题,旨在寻找图(由结点和路径组成的)中两结点之间的最短路径。

最短路径不一定是经过边最少的路径,但在这些最短路径中,长度最短的那一条路径上只有一条边,且它的权值在从源点出发的所有边的权值最小。

算法具体的形式包括:

  • 确定起点的最短路径问题:也叫单源最短路问题,即已知起始结点,求最短路径的问题。
  • 确定终点的最短路径问题:与确定起点的问题相反,该问题是已知终结结点,求最短路径的问题。在无向图中该问题与确定起点的问题完全等同,在有向图中该问题等同于把所有路径方向反转的确定起点的问题。
  • 确定起点终点的最短路径问题:即已知起点和终点,求两结点之间的最短路径。
  • 全局最短路径问题:也叫多源最短路问题,求图中所有的最短路径。

用于解决最短路径问题的算法被称做“最短路径算法”,有时被简称作“路径算法”。最常用的路径算法有:Dijkstra算法、A*算法、Bellman-Ford算法、SPFA算法(Bellman-Ford算法的改进版本)、Floyd-Warshall算法、Johnson最短路算法。

二、迪杰斯特拉(Dijkstra)算法

迪杰斯特拉(Dijkstra)算法是由荷兰计算机科学家艾兹赫尔·韦伯·迪杰斯特拉(Edsger Wybe Dijkstra),又译艾兹赫尔·韦伯·戴克斯特拉于1959年提出的,因此又叫戴克斯特拉。

Dijkstra 算法是从一个顶点到其余各顶点的最短路径算法,解决的是有权图中最短路径问题。迪杰斯特拉算法主要特点是从起始点开始,采用贪心算法的策略,每次遍历到始点距离最近且未访问过的顶点的邻接节点,直到扩展到终点为止。
在这里插入图片描述

1. 算法思想

迪杰斯特拉算法的主要思想是通过不断更新顶点之间的最短路径,逐步找到从指定起点到各个顶点的最短路径。该算法以贪心策略为基础,在每一步选择当前最优的顶点,并根据该顶点更新其他顶点的距离值,确保已确定的最短路径不再被修改。通过反复进行这样的选择和更新,最终得到了从起点到所有其他顶点的最短路径。

总的来说,迪杰斯特拉算法的思想就是以逐步迭代的方式,通过不断选择当前最优的顶点,更新其他顶点的距离值,直至得到起点到各个顶点的最短路径。

2. 算法步骤

  1. 初始化:创建一个集合 Q 存放未确定最短路径顶点,初始包含所有顶点;创建一个集合 S 存放所有已知实际最短路径值的顶点,初始为空;创建一个数组 dist 存放最短距离数组,记录每个顶点到起点的最短距离,初始值都为无穷大,起点的距离为0。
  2. 选取起点:从集合 Q 中选取一个离起点距离最短的顶点,将其移动到集合 S 中。
  3. 更新距离:对于当前确定最短路径的顶点,遍历其所有相邻顶点,如果通过当前顶点到达相邻顶点的距离小于相邻顶点当前记录的最短距离,则更新相邻顶点的最短距离为新的距离值,更新完相邻顶点的最短距离后,将这些顶点从集合 Q 移动到集合 S
  4. 重复步骤2和步骤3,直到集合 Q 为空。
  5. 最终得到起点到每个顶点的最短路径。

三、弗洛伊德(Frolyd)算法

弗洛伊德(Floyd-Warshall,Floyd )算法又称为插点法,是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法。该算法名称以创始人之一、1978年图灵奖获得者、斯坦福大学计算机科学系教授罗伯特·弗洛伊德(Robert W. Floyd)命名。

Floyd 算法以动态规划为基础,该算法通过不断更新顶点之间的最短路径长度,以找到任意两个顶点之间的最短路径长度。

1. 算法思想

弗洛伊德算法的算法思想是通过动态规划的方式来求解图中所有点对之间的最短路径。该算法的核心思想是利用一个中间顶点集合,逐步缩小这个集合的规模,更新并维护每对顶点之间的最短路径长度。

具体而言,弗洛伊德算法通过多次迭代,尝试在已知顶点之间的最短路径基础上,考虑添加一个新的中间顶点后是否可以缩短路径长度。如果存在更短的路径,就更新当前已知的最短路径长度;否则保持原状。不断重复这个过程,最终得到所有点对之间的最短路径长度矩阵。

弗洛伊德算法的动态规划思想在于利用已知的最短路径信息来推导出更长路径的最短路径,通过不断更新和迭代,最终得到所有顶点之间的最短路径长度。

2. 算法步骤

  1. 初始化:创建一个二维数组 distance,其中 distance[i][j] 表示顶点 i 到顶点 j 的最短路径长度。将 distance[i][j] 初始化为连接顶点 i 和 j 的边的权重。如果不存在直接相连的边,则将 distance[i][j] 初始化为无穷大。

  2. 更新最短路径:对于每对顶点 i 和 j,遍历所有顶点 k,比较通过顶点 k 是否可以使顶点 i 到 j 的路径变得更短,即检查 distance[i][k] + distance[k][j] 是否小于当前已知的 distance[i][j]。如果是,则更新 distance[i][j] = distance[i][k] + distance[k][j]。

  3. 重复更新:重复执行步骤2,直到所有顶点对之间的最短路径长度都被计算出来。

  4. 检查负权回路:如果存在负权回路,即顶点到自身的距离小于0,说明图中存在无限可减小的路径长度,算法将无法正常运行。

  5. 最终得到所有点对之间的最短路径长度矩阵。

四、最短路径算法对比

如果遇到单源且边为正数,直接Dijkstra。
至于 使用朴素版还是 堆优化版 还是取决于图的稠密度, 多少节点多少边算是稠密图,多少算是稀疏图,这个没有量化,如果想量化只能写出两个版本然后做实验去测试,不同的判题机得出的结果还不太一样,一般情况下,可以直接用堆优化版本。

如果是遇到多源点求最短路,直接 Floyd。

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

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

相关文章

JSON文件转YOLO文件示例

文章目录 前言一、步骤指南二、代码实现1.类别名称到ID的映射2.边界框转换函数3.JSON解码函数4.主程序 前言 将JSON标注文件转换为YOLO格式通常涉及从JSON文件中提取图像尺寸、对象类别和边界框坐标,并将这些信息格式化为YOLO格式所需的格式。YOLO格式通常要求每行…

ubuntu编译ffmpeg

配置 运行环境:vmware ubuntu 20.04 时间:2024年10月24日 权限问题:由于ubuntu权限问题 建议使用root权限编译,且~是根据用户组来进行定位的。 环境配置更新 cd ~ && \ mkdir ffmpeg_sources ffmpeg_build bin &…

EasyExcel自定义下拉注解的三种实现方式

文章目录 一、简介二、关键组件1、ExcelSelected注解2、ExcelDynamicSelect接口(仅用于方式二)3、ExcelSelectedResolve类4、SelectedSheetWriteHandler类 三、实际应用总结 一、简介 在使用EasyExcel设置下拉数据时,每次都要创建一个SheetWr…

【vs2022】windows可用的依赖预编译库

ffmpeg 、x264 、x265 等。obs是基于qt6+vs2022+64bit obs的官网传统构建已经不用了obs的s2022构建OBS Deps Build 2024-09-12FFmpeg4.4 库,x64 可用。

每天五分钟深度学习pytoroch:基于pytorch搭建逻辑回归算法模型

本文重点 前面我们学习了线性回归模型的搭建,无论是基于pytorch还是不基于pytorch,以上的模型都是回归模型,本文我们将使用pytorch搭建逻辑回归模型,逻辑回归模型是一个经典的分类问题。 模型搭建 class LogisticRegression(nn.Module) : def __init__(self) :super (Lo…

嵌入式软件 Bug 排查与调试技巧

目录 1、准备工作 2、打印调试 实现步骤 注意事项 3、断点调试 4、观察点调试 5、远程调试 6、内存分析 内存泄漏检测 栈溢出检测 7、异常处理 8、性能分析 9、逻辑分析仪 10、示波器 11、常见bug类型 12、调试策略 1、准备工作 硬件工具准备 调试器:例如 J - …

玩转Docker | 使用Docker部署推箱子网页小游戏

玩转Docker | 使用Docker部署推箱子网页小游戏 一、项目介绍项目简介项目预览 二、系统要求环境要求环境检查Docker版本检查检查操作系统版本 三、部署推箱子网页小游戏下载镜像创建容器检查容器状态检查服务端口安全设置 四、访问推箱子网页小游戏五、总结 一、项目介绍 项目…

什么是服务器?服务器与客户端的关系?本地方访问不了网址与服务器访问不了是什么意思?有何区别

服务器是一种高性能的计算机,它通过网络为其他计算机(称为客户端)提供服务。这些服务可以包括文件存储、打印服务、数据库服务或运行应用程序等。服务器通常具有强大的处理器、大量的内存和大容量的存储空间,以便能够处理多个客户…

Iperius Backup(数据备份软件) v8.3.0 中文免费版

下载: 【1】https://pan.quark.cn/s/19ef716c02d5 【2】https://drive.uc.cn/s/197acba8d8d94?public1 Iperius Backup是一款专业的备份还原软件,功能强大,支持DAT备份、LTO备份、NAS备份、磁带备份、RDX驱动器、USB备份,满足用…

SOES(EtherCAT)从站API梳理

1. void ESC_config (esc_cfg_t * cfg); 功能:配置EtherCAT从站。参数:esc_cfg_t *cfg 指向配置结构体的指针,该结构体包含从站的配置参数。解释:该函数用于初始化或更新从站的配置,如通信参数、同步管理器设置等。 …

Java Lock Condition 总结

前言 相关系列 《Java & Lock & 目录》(持续更新)《Java & Lock & Condition & 源码》(学习过程/多有漏误/仅作参考/不再更新)《Java & Lock & Condition & 总结》(学习总结/最新最准…

K8S测试pod内存和CPU资源不足

只设置requests参数 mysql主从pod启动后监控 读压测之后 同时设置limits和requests,只调低内存值 监控 压力测试 同时设置limits和requests,只调低CPU值 初始状态 开始压测 结论 对于CPU,如果pod中服务使用CPU超过设置的limits&…

谷歌云GCP基础概念讲解

概览 云的基础是虚拟化:服务器,存储,网络。服务器是远程计算机的逻辑分区。存储是物理硬盘的逻辑划分。网络则是虚拟私有云。 谷歌是唯一一个拥有全球私有基础设施的公司;他们的谷歌云基础设施没有任何一部分通过公共互联网。换句…

绿盟科技发布三季度报告,收入略增,亏损收窄,经营性净现金流同比翻倍

10月30日,绿盟科技发布2024年三季度报告。2024年公司前三季度实现营业收入12.74亿元,同比增长5.57%;毛利率59.50%,同比增长4.76个百分点;期间费用总额同比下降7.68%;公司实现归属于上市公司股东的净利润-3.…

【云原生】云原生后端详解:架构与实践

目录 引言一、云原生后端的核心概念1.1 微服务架构1.2 容器化1.3 可编排性1.4 弹性和可伸缩性 二、云原生后端的架构示意图三、云原生后端的最佳实践3.1 使用服务网格3.2 监控与日志管理3.3 CI/CD 流水线3.4 安全性 总结参考资料 引言 随着云计算的迅猛发展,云原生…

Python 爬虫的寻宝大冒险:如何捕获 API 数据的宝藏

在这个信息爆炸的数字时代,数据就像是隐藏在网络深处的宝藏,等待着勇敢的探险家去发现。今天,我们要讲述的是如何成为一名 Python 爬虫探险家,装备你的代码工具,深入 API 的迷宫,捕获那些珍贵的数据宝藏。 …

C++-类与对象总结

const函数声明 1. 修饰成员函数,不会改变成员变量: - a function b const (c){}: in member function means, all member properties in the function cannot be modified. 2.修饰形参,输入参数在函数中不会被更改,提高程序的…

《近似线性可分支持向量机的原理推导》 拉格朗日函数 公式解析

本文是将文章《近似线性可分支持向量机的原理推导》中的公式单独拿出来做一个详细的解析,便于初学者更好的理解。 公式 9-41 解释: L ( w , b , ξ , α , μ ) 1 2 ∥ w ∥ 2 C ∑ i 1 N ξ i − ∑ i 1 N α i ( y i ( w T x i b ) − ( 1 − ξ …

【云原生】云原生后端:安全性最佳实践

目录 引言一、身份管理1.1 身份验证1.2 身份授权 二、数据加密2.1 数据静态加密2.2 数据传输加密2.3 密钥管理 三、网络安全3.1 网络隔离3.2 防火墙与入侵检测3.3 安全组与网络访问控制列表 (NACL) 结论 引言 在云原生架构中,安全性是一个至关重要的考量。随着应用…

C++,STL 051(24.10.28)

内容 1.map容器的构造函数。 2.map容器的赋值操作。 运行代码 #include <iostream> #include <map>using namespace std;void printMap(map<int, int> &m) {for (map<int, int>::iterator it m.begin(); it ! m.end(); it){cout << &quo…