首页 > 编程语言 > 详细

Floyd-弗洛伊德算法

时间:2019-03-01 23:49:21      阅读:226      评论:0      收藏:0      [点我收藏+]

今天,研究一下谁都能看懂的弗洛伊德算法。

 

首先,弗洛伊德算法是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法。

这个算法需要一个用到一个二维数组啊a[][],而a[i][j]表示的就是,i到j的距离。

而在一个图中,可能会存在k,i到k再到j的距离可能会更短,也就是a[i][k]+a[k][j]<a[i][j]

技术分享图片(转)

如上图中,4到3的距离为12,但如果4先到1,再到3,距离就会缩短到5+6=11。再继续往后推,如果路线为4->1->2->3的话,距离会被缩短到5+2+3=10。这个时候,我们就可以把a[4][3]刷新成10了。

代码如下

1 for (int i=1; i<=n; i++)
2     for (int j=1; j<=n; j++)
3         for (int k=1; k<=n; k++)
4             if (a[i][k]+a[k][j]<a[i][j])
5                 a[i][j]=a[i][k]+a[k][j];

 

Floyd-弗洛伊德算法

原文:https://www.cnblogs.com/Alan-Anders/p/10459180.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!