Bellman-Ford算法和SPFA算法

Belloman-Ford算法

算法介绍

Dijkstra可以解决单源无负边最短路径问题。但是当遇到含有负边的单源最短路径问题就需要使用Bellman-Ford算法来解决。Bellman-Ford算法还可以检测出负环。

算法步骤

  • 源点s,数组d[u]d[u]d[u]表示s到u的最短距离
  • 初始化:d[s]=0d[s]=0d[s]=0,∀v∈V−{s},d[v]=∞\forall v \in V-\{s\},d[v]=\infinvV{s},d[v]=
  • 循环∣V∣−1|V|-1V1次,每次对每条边进行松弛操作:对于有向边(u,v)(u,v)(u,v),如果d[u]+w[u,v]<d[v]d[u]+w[u,v]<d[v]d[u]+w[u,v]<d[v],则d[v]=d[u]+w[u,v]d[v]=d[u]+w[u,v]d[v]=d[u]+w[u,v]
  • 对每条边进行松弛操作,如果操作成功,说明有负环。否则最后的d[i]d[i]d[i]就是源点s到i的最短路径长度

我们可以看到Bellman-Ford算法的算法结构是比较简单的,复杂度是O(VE)O(VE)O(VE),比Dijkstra算法最好为O(E+VlogV)O(E+VlogV)O(E+VlogV)大,但是可以处理负边。

正确性证明

可以看到算法的核心操作就是松弛。这就要用到另一篇博客中介绍Dijkstra算法的时候的几个关于松弛操作的引理,这里就不再进行证明,如果想要看证明可以移步:传送门。

设源点为s,d[u]表示源点到u的最短路径,w[u,v]表示从点u到点v的一条有向边的长度,δ(u,v)\delta(u,v)δ(u,v)表示u到v的最短路径。

最优子结构:任意两点之间的最短路径的子路径仍然是最短路径
引理1:初始化以后∀v∈V,d[u]⩾δ(s,v)\forall v \in V,d[u]\geqslant\delta(s,v)vV,d[u]δ(s,v)
引理2:假设存在s到v的最短路径:s->…->u->v,d[u]=δ(s,u)d[u]=\delta(s,u)d[u]=δ(s,u),那么在对边(u,v)进行松弛操作以后d[v]=δ(s,v)d[v]=\delta(s,v)d[v]=δ(s,v)

假设没有负边环,那么:

  • 对于初始情况,d[s]=0=δ(s,s)d[s]=0=\delta(s,s)d[s]=0=δ(s,s)

因为如果d[s]<0d[s]<0d[s]<0说明存在一个环s->…->s的权值和为负,而假设没有负边环,所以不存在这样的情况

  • 假设对于最短路径经过边数为k的点u在第k次循环d[u]=δ(s,u)d[u]=\delta(s,u)d[u]=δ(s,u),那么由引理2,所有最短路径经过边数为k+1的点v在第k+1次循环后,d[v]=δ(s,v)d[v]=\delta(s,v)d[v]=δ(s,v)
  • 因为一个节点数目为∣V∣|V|V的图的简单路径最长为∣V∣−1|V|-1V1,所以∣V∣−1|V|-1V1次循环以后∀v∈V,d[v]=δ(s,v)\forall v \in V,d[v]=\delta(s,v)vV,d[v]=δ(s,v)
  • 第|V|次循环应该无法进行松弛操作。

如果第|V|次循环可以进行松弛操作,则由逆反命题,说明有负边环。

证毕。

SPFA算法

算法介绍

SPFA算法是对Bellman-Ford算法的优化。因为Bellman-Ford算法中会对已经确定最短路径的点进行松弛判断,但这实际上是不必要的。我们需要松弛的是被松弛的点可以到达的点。正是这种思想我们有了SPFA算法。

算法步骤

  • 源点s,数组d[u]d[u]d[u]表示s到u的最短距离,队列Q表示需要操作进行松弛操作的点的集合
  • 初始化:d[s]=0,∀v∈V−{s},d[v]=∞d[s]=0,\forall v \in V-\{s\},d[v]=\infind[s]=0,vV{s},d[v]=,将点s加入Q中
  • 从Q中取出一个点,对它可以到达的点进行松弛操作,并将成功进行松弛操作的点加入Q中
  • 重复上述步骤直到Q为空
  • 如果某个点被松弛了|V|次,说明有负边环

正确性证明

同Bellman-Ford算法,可以用归纳法进行证明。本质上SPFA算法提取出了Bellman-Ford算法中有效的操作。

复杂度分析

可以构造图使得算法复杂度为O(VE)O(VE)O(VE),因此算法的最坏复杂度为O(VE)O(VE)O(VE)。虽然SPFA算法是Bellman-Ford算法的优化,但是对于一些特殊的图可能因为有判断操作和出队入队操作导致两者复杂度相近。

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

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

相关文章

C语言实现单链表操作

SLIST_H #ifndef __SLIST_H__ #define __SLIST_H__ #include<cstdio> #include<malloc.h> #include<assert.h> typedef int ElemType; typedef struct Node { //定义单链表中的结点信息 ElemType data; //结点的数据域 struct Node *next; //结点的指针…

计算机网络【4】传输层

概述 传输层是只有主机才有的层次 传输层的功能&#xff1a; 传输层提供进程和进程之间的逻辑通信&#xff08;网络层提供主机与主机之间的逻辑通信&#xff09;复用和分用传输层对收到的报文进行差错检测 传输层有两个协议&#xff1a; 面向连接的传输层控制协议TCP&…

Plotly绘图

在做Python数据分析实验的时候发现使用Plotly库绘图比较漂亮&#xff0c;在网上找到了一个比较好的教程&#xff0c;这里记录一下&#xff0c;方便以后查找。 传送门

计算机网络【0】概述

计算机网络概念和功能 概念 是一个将分散的、具有独立功能的计算机系统&#xff0c;通过通信设备与线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统。 计算机网络是互连的、自治&#xff08;无主从关系&#xff09;的计算机集合。 功能 数据通信&am…

计算机网络【1】物理层

物理层解决如何在连接各种计算机的传输媒体上传输数据比特流&#xff0c;而不是指具体的传输媒体。 确定与传输媒体接口有关的特性 机械特性&#xff1a;定义物理连接的特性&#xff0c;如规格、接口形状、引线数目、引脚数目、排列电气特性&#xff1a;规定传输二进制位时的电…

计算机网路【2】数据链路层

结点&#xff1a;主机、路由器 链路&#xff1a;两个节点的物理通道 数据链路&#xff1a;逻辑通道&#xff0c;把实现 控制数据传输协议的硬件和软件加到链路上就构成数据链路 帧&#xff1a;链路层的协议数据单元&#xff0c;封装网络层数据报 数据链路层在物理层提供服务的…

计算机网络【5】应用层

应用层对应用程序的通信提供服务 应用层协议定义&#xff1a; 应用层的功能&#xff1a; 文件传输、访问和管理电子邮件虚拟终端查询服务和远程作业登录 重要协议&#xff1a;FTP、SMTP、POP3、HTTP、DNS 网络应用模型 客户/服务器模型&#xff08;Client/Server&#x…

操作系统【八】文件管理

文件&#xff1a;一组有意义的信息/数据集合 文件的属性&#xff1a; 文件名&#xff1a;由创建文件的用户决定文件名&#xff0c;主要是为了方便用户找到文件。同一个目录下不允许有重名文件标识符&#xff1a;一个系统内的个文件标识符唯一&#xff0c;对用户来说毫无可读性…

数据库原理及应用【六】数据库设计

数据依赖 函数依赖FD&#xff1a;一个属性或者一组属性的值可以决定另一个属性的值 多值依赖MVD&#xff1a;一个属性或者一组属性的值可以决定另一个属性的值的集合。FD是MVD的特例 符号表示&#xff1a;Name->->Course&#xff0c;课程多值依赖于姓名 连接依赖&#x…

数据可视化【一】JavaScript学习

本博客是我学习Curran Kelleher老师数据可视化课程的笔记&#xff0c;感兴趣的小伙伴可以点击这里学习。 three cores of data visualization: analysisdesignconstruction 推荐书籍《visualization analysis & design》 使用https://vizhub.com/进行编程学习&#xff…

数据库原理及应用【二】数据模型

层次模型 tree Record and fieldParent-Child relationship(PCR) 每个记录类型只有一个父节点 无法表达多对多信息 采用虚记录解决多对多 网状数据模型 系&#xff1a;主记录->属记录 主记录和属记录都可以有好多个 关系模型 表&#xff1a;table/relation 拥有更高的…

数据可视化【二】HTML+CSS+SVG+D3

HTML、CSS和SVG学习实现代码&#xff1a;https://vizhub.com/Edward-Elric233/89185eb96bc64a9d81777873a0ccd0b9 index.html <!DOCTYPE html> <html><head><title>Shapes with SVG and CSS</title><link rel"stylesheet" href&qu…

数据可视化【三】基本概念

Visualization is suitable when there is a need to augment human capabilities rather than replace people with computational decision-making methods. 当可以信赖的智能化的解决方案存在的时候&#xff0c;可视化是不必要的。 当不知道需要分析的问题是什么的时候&…

数据可视化【四】Bar Chart

Make a Bar Chart Representing a data table in JavaScriptCreating rectangles for each rowUsing linear and band scalesThe margin conventionAdding axes 以下学习内容参考博客&#xff1a;传送门 select()选择所有指定元素的第一个 selectAll()选择指定元素的全部 上…

数据库原理及应用【三】DBMS+SQL

DBMS Query LanguagesInterface and maintaining tools(GUI)APIsClass Library QL 不是图灵完备的&#xff0c;不是一种编程语言。 QL SQL是一种非过程化的查询语言。 DDL数据定义语言&#xff1a;表&#xff0c;视图QL 查询语言DML 数据操纵语言DCL 数据控制语言 Base t…

数据可视化【五】 Scatter Plot

Scatter Plot vizhub上实现的代码&#xff1a; https://vizhub.com/Edward-Elric233/53807a1b35d94329b3689081cd2ea945 https://vizhub.com/Edward-Elric233/b9647d50899a4a0e8e917f913cd0a53a https://vizhub.com/Edward-Elric233/8c6b50cd81a04f048f490f48e4fe6264 由前…

数据可视化【六】Line Chart Area Chart

Line Chart vizhub代码&#xff1a; https://vizhub.com/Edward-Elric233/094396fc7a164c828a4a8c2e13045308 实现效果&#xff1a; 这里先使用d3.line()设置每个点的x坐标和y坐标&#xff0c;然后再用这个东西设置path的d属性&#xff0c;就可以得到曲线。 const lineGen…

数据可视化【七】 更新模式

Enter 以下面这个简单的代码进行分析 const svg d3.select(svg); // svg.style(background-color, red); testconst height svg.attr(height); // equals paresFloat() const width svg.attr(width);const makeFruit type >( {type} ); //这种写法好像能够直接得到一个…

数据可视化【八】根据数据类型选择可视化方式

Marks:Rows PointsLinesAreas Channels:Columns PositionColorShape

数据可视化【九】单向数据流交互

我们使用一下上上篇博客的代码。 例如我们想要当鼠标点击水果的时候会出现黑色的框&#xff0c;再点击一下黑色的框就会消失。 首先&#xff0c;我们应该给组件添加点击事件&#xff1a; fruitBowl.js gruopAll.on(click, d > onClick(d.id));这个on函数第一个参数是事件…