图论part10 bellman_ford算法

  1. bellman_ford算法:对所有边进行松弛N-1次操作,求得目标最短路

卡码网94:寻找从节点1到节点n的最短路径并计算路径总权值,输出权值;不存在路径输出unconnected

  1. 松弛

状态一: minDistA + value 可以推出 minDistB

状态二: minDistB本身就有权值 (可能是其他边链接的节点B 例如节点C,以至于 minDistB记录了其他边到minDistB的权值)

对状态一二进行选择得过程就叫松弛

if (minDistB > minDistA + value) minDistB = minDistA + value

  1. 为什么松弛n-1次?

只要知道松弛一次得到的是到达和起点一条边相连得节点最短距离

到达节点n的最短距离就能通过松弛n-1次得到,同时还能得到到所有节点的最短距离

  1. 不能从未计算过路径的节点出发

  2. SFPA算法

适用队列优化bellman_ford,简单来记就是邻接表存图(维护边),BFS,并使用标记数组对目标节点进行标记,但是需要有取消标记的操作

  1. 判断负权回路,由该系列算法可知我们通过n-1次松弛可以得到从起点到任意一点的最少开销,如果存在负权回路,再继续松弛,就是沿着该回路绕圈,会使开销越来越小。判断方法就是松弛n-1次后在松弛一次看minDist数组有没有变化
相关推荐
Jerry3 小时前
LeetCode 209. 长度最小的子数组
算法
彦为君3 小时前
算法思维与经典智力题
java·前端·redis·算法
智能优化与强化学习3 小时前
Gym(Gymnasium)仿真环境详解(二):环境简介、入门算法、调参要点、核心挑战
算法·强化学习·gym·零基础入门·算法评估
mxwin4 小时前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader
“码”力全开4 小时前
AI视频分析误报优化完整流程
算法·架构·边缘计算
深盾科技_Virbox4 小时前
深盾科技·Virbox产品体系全景解读:软件安全如何从加密锁走向全生命周期
java·大数据·算法·安全·软件需求
可编程芯片开发4 小时前
基于VSG虚拟同步发电机控制的三相并网逆变器带多组可变负载Simulink建模与仿真
算法
AI服务老曹4 小时前
国产NPU视觉算法参数配置说明
算法·性能优化·边缘计算
彦为君4 小时前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
触底反弹5 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法