Floyd-Warshall 算法-- 最短路径(适合节点密集的图)
由于此算法时间复杂度为O(V³)。大多数情况下不如迪杰斯特拉算法的
。迪杰斯特拉算法适合于节点疏散的图。
演示样例图例如以下:
Step 1 创建节点与边的最短路径结果表(直接可达关系)。数值表示距离。INF表示不可达
|
|
1 |
2 |
3 |
4 |
|
1 |
0 |
8 |
INF |
1 |
|
2 |
INF |
0 |
1 |
INF |
|
3 |
4 |
INF |
0 |
INF |
|
4 |
INF |
2 |
9 |
0 |
Step2 找出全部经过1的路径。更新两点间的最短路径
经过1的路径即全部入度和出度路径的组合,总数为入度×出度:
经过1路径为:
第一条,3-1-2
眼下MIN(3->2)为INF,而MIN(3->1->2)=4+8=12 因此MIN(3->2)为12,由于2有更新,故要递归更新全部从3到2可达点的最短路径。而2可达点仅仅有3,MIN(3->3)为0,因此不须要更新。
第二条,3-1-4
眼下MIN(3->4)为INF,而MIN(3->1->4)=4+1=5,因此MIN(3->4)为5,由于4有更新,故要递归更新全部从3到4的全部可达点的最短路径,而4的可达点为3和2:
MIN(3->3)=0,MIN(3->2)=MIN(3->1->2)=12 > MIN(3->1->4->2)= 7。因此MIN(3->2)=7
找出全部经过1路径的结果为:
|
|
1 |
2 |
3 |
4 |
|
1 |
0 |
8 |
INF |
1 |
|
2 |
INF |
0 |
1 |
INF |
|
3 |
4 |
0 |
||
|
4 |
INF |
2 |
9 |
0 |
Step3 找出全部经过2的路径
第1条,1->2->3
由于MIN(1->3)为INF,而MIN(1->2->3)为9。因此MIN(1->3)为9,由于3有更新,所以须要递归更新全部从1到3可达点的最短路径,由于3的可达点为1,而MIN(1->1)不须要更新,为0。如今看第二条路径:
第二条。4->2->3
因此MIN(4->3)为9,而MIN(4->2->3)为3。因此MIN(4->3)=3,由于3有更新,须要递归更新从4到3可达点的最短路径,由于3的可达点为1,而MIN(4->1)为INF,MIN(4->2->3->1)为7。因此MIN(4->1)为7。由于1有更新,继续递归,1的可达点为4和2,MIN(4->4)保持0;眼下MIN(4->2)为2,而MIN(4->2->3->1->2)=2+1+4+8=15大于2。因此不须要更新。
找出全部经过2的路径后,结果为:
|
|
1 |
2 |
3 |
4 |
|
1 |
0 |
8 |
1 |
|
|
2 |
INF |
0 |
1 |
INF |
|
3 |
4 |
7 |
0 |
5 |
|
4 |
2 |
0 |
Step4 找出全部经过3的路径
第1条。4->3->1
MIN(4->1)为7。而MIN(4->3->1)为13。因此不须要更新
第二条,2->3->1
由于MIN(2->1)为INF,而MIN(2->3->1)为5。因此须要更新MIN(2->1)为5。
由于更新了1,因此须要更新全部从2到1可达点的路径,1的可达点为4和2,MIN(2->2)不须要更新;眼下MIN(2->4)为INF。而MIN(2->3->1->4)为6。因此MIN(2->4)为6。由于更新了4,因此须要递归更新从2到4可达点的路径,4可达点为2和3,MIN(2->2)为0;MIN(2->3)为1小于MIN(2->3->1->4->3)=1+4+1+9=15。故也不须要更新。
所以经过这一步,结果表为:
|
|
1 |
2 |
3 |
4 |
|
1 |
0 |
8 |
9 |
1 |
|
2 |
5 |
0 |
1 |
6 |
|
3 |
4 |
7 |
0 |
5 |
|
4 |
7 |
2 |
3 |
0 |
最后,找出经过4的路径。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
第一条。1->4->2
MIN(1->2)为8,而MIN(1->4->2)为3,因此MIN(1->2)更新为3,由于更新了2。故须要更新全部从1到2可达点的最短路径,2的可达点为3。MIN(1->3)眼下为9。而MIN(1->4->2->3)为4,因此MIN(1->3)更新为4。由于更新了3。故递归更新全部从1到3可达点的最短路径,3的可达点为1,而MIN(1->1)不须要更新保持为0。
第二条,1->4->3
MIN(1->3)为4,而MIN(1->4->3)为10。因此不须要更新。
所以终于结果为:
|
|
1 |
2 |
3 |
4 |
|
1 |
0 |
1 |
||
|
2 |
5 |
0 |
1 |
6 |
|
3 |
4 |
7 |
0 |
5 |
|
4 |
7 |
2 |
3 |
0 |
Floyd-Warshall 算法-- 最短路径(适合节点密集的图)的更多相关文章
- Floyd—Warshall算法
我们用DP来求解任意两点间的最短路问题 首先定义状态:d[k][i][k]表示使用顶点1~k,i,j的情况下,i到j的最短路径 (d[0][i][j]表示只使用i和j,因此d[0][i][j] = c ...
- 图论之最短路径(1)——Floyd Warshall & Dijkstra算法
开始图论学习的第二部分:最短路径. 由于知识储备还不充足,暂时不使用邻接表的方法来计算. 最短路径主要分为两部分:多源最短路径和单源最短路径问题 多源最短路径: 介绍最简单的Floyd Warshal ...
- 数据结构与算法--最短路径之Floyd算法
数据结构与算法--最短路径之Floyd算法 我们知道Dijkstra算法只能解决单源最短路径问题,且要求边上的权重都是非负的.有没有办法解决任意起点到任意顶点的最短路径问题呢?如果用Dijkstra算 ...
- WarShall算法
1.引言 图的连通性问题是图论研究的重要问题之一,在实际中有着广泛的应用.例如在通信网络的联通问题中,运输路线的规划问题等等都涉及图的连通性.因此传递闭包的计算需要一个高效率的算法,一个著名的算法就是 ...
- Gym 101873D - Pants On Fire - [warshall算法求传递闭包]
题目链接:http://codeforces.com/gym/101873/problem/D 题意: 给出 $n$ 个事实,表述为 "XXX are worse than YYY" ...
- 数据结构与算法--最短路径之Bellman算法、SPFA算法
数据结构与算法--最短路径之Bellman算法.SPFA算法 除了Floyd算法,另外一个使用广泛且可以处理负权边的是Bellman-Ford算法. Bellman-Ford算法 假设某个图有V个顶点 ...
- POJ 2253 Frogger(warshall算法)
题意:湖中有很多石头,两只青蛙分别位于两块石头上.其中一只青蛙要经过一系列的跳跃,先跳到其他石头上,最后跳到另一只青蛙那里.目的是求出所有路径中最大变长的最小值(就是在到达目的地的路径中,找出青蛙需要 ...
- 分布式ID系列(5)——Twitter的雪法算法Snowflake适合做分布式ID吗
介绍Snowflake算法 SnowFlake算法是国际大公司Twitter的采用的一种生成分布式自增id的策略,这个算法产生的分布式id是足够我们我们中小公司在日常里面的使用了.我也是比较推荐这一种 ...
- [C++]动态规划系列之Warshall算法
/** * * @author Zen Johnny * @date 2018年3月31日 下午8:13:09 * */ package freeTest; /* [动态规划系列:Warshall算法 ...
随机推荐
- codeforces248(div1) B Nanami's Digital Board
q次询问,每次询问能够对矩阵某一个值改变(0变1.1变0) 或者是查询子矩阵的最大面积,要求这个这个点在所求子矩阵的边界上,且子矩阵各店中全为1 用up[i][j]表示(i,j)这个点向上能走到的最长 ...
- light oj 1317
Description You probably have played the game "Throwing Balls into the Basket". It is a si ...
- android JNI 一维数组、二维数组的访问与使用
在JNI中访问JAVA类中的整型.浮点型.字符型的数据比较简单,举一个简单的例子,如下: //得到类名 jclass cls = (*env)->GetObjectClass(env, obj) ...
- VS导出方法名和方法备注的方法
VS导出方法名和方法备注的方法 方法一: 只能导出图片格式的UML 类图 1.点击查看类图 2.在空白处点击讲关系导出为图像 方法二: 是把整个类库的方法名都罗列出来 这个方便整理一些 具体方法如下 ...
- 关于docker部署javaweb应用的问题
我做了两个镜像,一个mysql,一个tomcat.建完mysql容器之后,在建tomcat的时候用--link把他们链接起来了进tomcat的容器里面 /etc/hosts 也发现了mysql的ip但 ...
- codeforces 544 D Destroying Roads 【最短路】
题意:给出n个点,m条边权为1的无向边,破坏最多的道路,使得从s1到t1,s2到t2的距离不超过d1,d2 因为最后s1,t1是连通的,且要破坏掉最多的道路,那么就是求s1到t1之间的最短路 用bfs ...
- 日常基础—————echo,print,print_r,var_dump的区别
1.echo 函数输出一个或多个字符串. 代码: header("Content-Type:text/html; charset=utf-8"); echo "你好” ...
- Leaflet绘制多边形
drawPolygon = () => { let points = []; const polygon = new L.Polygon(points); this.map.addLayer(p ...
- luogu P3157 [CQOI2011]动态逆序对(CDQ分治)
题目描述 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计整个序列的逆序 ...
- Windows改动cmd字符集
在中文Windows系统中,假设一个文本文件是UTF-8编码的,那么在CMD.exe命令行窗体(所谓的DOS窗体)中不能正确显示文件里的内容.在默认情况下,命令行窗体中使用的代码页是中文或者美国的,即 ...