floyd算法的原理 floyd算法介绍

floyd算法的原理 floyd算法介绍

【floyd算法的原理 floyd算法介绍】1、Floyd算法又称为插点法,是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法,与Dijkstra算法类似 。该算法名称以创始人之一、1978年图灵奖获得者、斯坦福大学计算机科学系教授罗伯特·弗洛伊德命名 。
2、在计算机科学中,Floyd-Warshall算法是一种在具有正或负边缘权重(但没有负周期)的加权图中找到最短路径的算法 。算法的单个执行将找到所有顶点对之间的最短路径的长度(加权) 。虽然它不返回路径本身的细节,但是可以通过对算法的简单修改来重建路径 。该算法的版本也可用于查找关系R的传递闭包,或(与Schulze投票系统相关)在加权图中所有顶点对之间的最宽路径 。

3、Floyd-Warshall算法是动态规划的一个例子 , 并在1962年由Robert Floyd以其当前公认的形式出版 。然而,它基本上与Bernard Roy在1959年先前发表的算法和1962年的Stephen Warshall中找到图形的传递闭包基本相同,并且与Kleene的算法密切相关 在1956年)用于将确定性有限自动机转换为正则表达式 。算法作为三个嵌套for循环的现代公式首先由Peter Ingerman在1962年描述 。
4、该算法也称为Floyd算法 , Roy-Warshall算法,Roy-Floyd算法或WFI算法 。

相关经验推荐