弗洛伊德(Floyd)算法
来源:互联网 发布:闲鱼 淘宝二手官网迈腾 编辑:程序博客网 时间:2024/05/16 13:41
弗洛伊德(Floyd)算法过程:
1、用D[v][w]记录每一对顶点的最短距离。
2、依次扫描每一个点,并以其为基点再遍历所有每一对顶点D[][]的值,看看是否可用过该基点让这对顶点间的距离更小。
算法理解:
最短距离有三种情况:
1、两点的直达距离最短。(如下图<v,x>)
2、两点间只通过一个中间点而距离最短。(图<v,u>)
3、两点间用通过两各以上的顶点而距离最短。(图<v,w>)
对于第一种情况:在初始化的时候就已经找出来了且以后也不会更改到。
对于第二种情况:弗洛伊德算法的基本操作就是对于每一对顶点,遍历所有其它顶点,看看可否通过这一个顶点让这对顶点距离更短,也就是遍历了图中所有的三角形(算法中对同一个三角形扫描了九次,原则上只用扫描三次即可,但要加入判断,效率更低)。
对于第三种情况:如下图的五边形,可先找一点(比如x,使<v,u>=2),就变成了四边形问题,再找一点(比如y,使<u,w>=2),可变成三角形问题了(v,u,w),也就变成第二种情况了,由此对于n边形也可以一步步转化成四边形三角形问题。(这里面不用担心哪个点要先找哪个点要后找,因为找了任一个点都可以使其变成(n-1)边形的问题)。
【转自】http://www.itweb2.com/article/system/317.htm
- 弗洛伊德(Floyd)算法
- 弗洛伊德(Floyd)算法
- 弗洛伊德(Floyd)算法
- 弗洛伊德(Floyd)算法
- Floyd算法(弗洛伊德算法)
- 弗洛伊德(Floyd)算法过程
- 弗洛伊德(Floyd)算法过程
- A*寻路 -- 弗洛伊德(Floyd)算法
- 最短路径--弗洛伊德(Floyd)算法
- 最短路-弗洛伊德(Floyd)算法
- 弗洛伊德(Floyd)算法 Java实现
- 最短路之Floyd(弗洛伊德)算法
- 多源最短路径问题-弗洛伊德(Floyd)算法
- 弗洛伊德算法(Floyd)
- 弗洛伊德(Floyd)算法
- 弗洛伊德(Floyd)算法
- 【弗洛伊德Floyd算法验证】
- 七龙珠 Floyd-Warshall 弗洛伊德算法
- 链表
- SecureCRT终端
- java网络编程基础知识
- linux下apache安装
- 新的一天,新的星期
- 弗洛伊德(Floyd)算法
- shell编程基础
- 选择和图像控件
- flex 载入数据
- C# 算兔子的算法 要求用递归
- flex 访问webservice
- 了解WCF定制的绑定类型(2)_绑定元素
- webservice服务器端以及使用,结合前面两个内容
- plsql配置 orcale基本语法 中文乱码