转:johnson算法的现实意义

简介: Johnson算法是一种用于解决边数与节点数之间关系为O(n^2)的带权图的最短路径问题的算法。它是一种结合了Dijkstra算法和Bellman-Ford算法的技术,通过使用一个负权重的环检测器来消除负权重的影响。这种算法的时间复杂度为O(n^2+m log n)。

Johnson算法是一种用于解决边数与节点数之间关系为O(n^2)的带权图的最短路径问题的算法。它是一种结合了Dijkstra算法和Bellman-Ford算法的技术,通过使用一个负权重的环检测器来消除负权重的影响。这种算法的时间复杂度为O(n^2+m log n)。

Johnson算法是一种用于解决多源最短路径问题的算法。它通过将图中的边权转换为虚拟起点的边权来解决问题。

Johnson算法的一个明显缺点是,在边权取负值之后,有负权边的图上不能使用该算法。这是因为负权边会导致最长路径不存在。另外,Johnson算法的时间复杂度为O(n^2 log(n) + m log(n)),其中n为顶点数,m为边数。相比于其他多源最短路径算法,Johnson算法的时间复杂度较高。还有一点就是Johnson算法需要先对图做一个Bellman-Ford或者Dijkstra来判断负环,并且需要多次使用堆优化的Dijkstra算法,所以空间复杂度也比较大。

例如,假设有一个图,其中包含5个节点(A、B、C、D、E)和7条边(A-B、B-C、C-D、D-E、A-D、B-E、C-E)。现在,如果要求从A、B、C三个起点到E终点的最短路径,可以使用Johnson算法。

首先,将虚拟起点S加入图中,并将S到A、B、C的边权设为0。然后,使用Bellman-Ford算法求S到其他各点的最短路径。接着,将图中所有边权加上S到该边的两个端点的最短路径长度。最后,使用Dijkstra算法求A、B、C到E的最短路径。

在这个例子中,Johnson算法将会得到A到E、B到E、C到E的最短路径分别为 [A,D,E], [B,E]。
image.png

本文转载自:https://www.teamdoc.cn/archives/2937

目录
相关文章
|
机器学习/深度学习 运维 算法
转:如何利用johnson算法实现企业上网行为监管
讨论如何用Johnson算法来监管企业上网行为,听起来有点儿像在为上网行为安排“时间表”,就像一个网络版的时间管理大师一样。大家都知道,Johnson算法是解决作业调度问题的高手,能让作业们排队有序,就像乖乖等着上舞台表演一样。虽然在作业调度领域它可是大红大紫,但要把它拉进企业上网监管的大舞台上,可能需要一点儿变脸技巧。
146 0
|
存储 算法
最短路Johnson算法
最短路Johnson算法
271 0
|
2月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
261 0
|
2月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
200 2
|
3月前
|
传感器 机器学习/深度学习 编解码
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
226 3
|
2月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
175 8
|
2月前
|
机器学习/深度学习 算法 自动驾驶
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
181 8