Floyd算法

1.定义概览

Floyd-Warshall算法(Floyd-Warshall algorithm)是解决任意两点间的最短路径的一种算法,可以正确处理有向图或负权的最短路径问题,同时也被用于计算有向图的传递闭包。Floyd-Warshall算法的时间复杂度为O(N3),空间复杂度为O(N2)。

2.算法描述

1)算法思想原理:

Floyd算法是一个经典的动态规划算法。用通俗的语言来描述的话,首先我们的目标是寻找从点i到点j的最短路径。从动态规划的角度看问题,我们需要为这个目标重新做一个诠释(这个诠释正是动态规划最富创造力的精华所在)

从任意节点i到任意节点j的最短路径不外乎2种可能,1是直接从i到j,2是从i经过若干个节点k到j。所以,我们假设Dis(i,j)为节点u到节点v的最短路径的距离,对于每一个节点k,我们检查Dis(i,k) + Dis(k,j) < Dis(i,j)是否成立,如果成立,证明从i到k再到j的路径比i直接到j的路径短,我们便设置Dis(i,j) = Dis(i,k) + Dis(k,j),这样一来,当我们遍历完所有节点k,Dis(i,j)中记录的便是i到j的最短路径的距离。

2).算法描述:

a.从任意一条单边路径开始。所有两点之间的距离是边的权,如果两点之间没有边相连,则权为无穷大。   

b.对于每一对顶点 u 和 v,看看是否存在一个顶点 w 使得从 u 到 w 再到 v 比己知的路径更短。如果是更新它。

3).Floyd算法过程矩阵的计算----十字交叉法(暂时没看懂,望大神指教)

方法:两条线,从左上角开始计算一直到右下角 如下所示

给出矩阵,其中矩阵A是邻接矩阵,而矩阵Path记录u,v两点之间最短路径所必须经过的点

相应计算方法如下:

最后A3即为所求结果

3.算法代码实现:

 1 typedef struct
 2 {
 3     char vertex[VertexNum];                                //顶点表
 4     int edges[VertexNum][VertexNum];                       //邻接矩阵,可看做边表
 5     int n,e;                                               //图中当前的顶点数和边数
 6 }MGraph;
 7
 8 void Floyd(MGraph g)
 9 {
10    int A[MAXV][MAXV];
11    int path[MAXV][MAXV];
12    int i,j,k,n=g.n;
13    for(i=0;i<n;i++)
14       for(j=0;j<n;j++)
15       {   
16              A[i][j]=g.edges[i][j];
17             path[i][j]=-1;
18        }
19    for(k=0;k<n;k++)
20    {
21         for(i=0;i<n;i++)
22            for(j=0;j<n;j++)
23                if(A[i][j]>(A[i][k]+A[k][j]))
24                {
25                      A[i][j]=A[i][k]+A[k][j];
26                      path[i][j]=k;
27                 }
28      }
29 }

算法时间复杂度:O(n3)

结合代码 并参照上图所示 我们来模拟执行下 这样才能加深理解:
第一关键步骤:当k执行到x,i=v,j=u时,计算出v到u的最短路径要通过x,此时v、u联通了。
第二关键步骤:当k执行到u,i=v,j=y,此时计算出v到y的最短路径的最短路径为v到u,再到y(此时v到u的最短路径上一步我们已经计算过来,直接利用上步结果)。
第三关键步骤:当k执行到y时,i=v,j=w,此时计算出最短路径为v到y(此时v到y的最短路径长在第二步我们已经计算出来了),再从y到w。

依次扫描每一点(k),并以该点作为中介点,计算出通过k点的其他任意两点(i,j)的最短距离,这就是floyd算法的精髓!同时也解释了为什么k点这个中介点要放在最外层循环的原因.

hdu-2544代码:

#include <stdio.h>
#include <string.h>
#define MAX 1000000
int map[110][110];
int n;
void flyod()
{int i,j,k;for(k=1;k<=n;k++)for(i=1;i<=n;i++){for(j=1;j<=n;j++)if(map[i][j]>(map[i][k]+map[k][j]))map[i][j]=map[i][k]+map[k][j];}printf("%d\n",map[1][n]);
}
int main()
{int m;while(scanf("%d %d",&n,&m),n||m){int i,j,a,b,c;for(i=0;i<=n;i++)for(j=0;j<=n;j++)map[i][j]=MAX;for(i=0;i<m;i++){scanf("%d %d %d",&a,&b,&c);if(c<map[a][b])map[a][b]=map[b][a]=c;}flyod();}return 0;
}
//ac
//flyod算法,31ms 

转载于:https://www.cnblogs.com/xl1027515989/p/3605553.html

最短路径--Floyd算法相关推荐

  1. C++ 实现带权有向图的每对顶点之间的最短路径Floyd算法(完整代码)

    基本思想是: 假设求从顶点vi到vj的最短路径. 如果从vi到vj有弧,则从vi到vj存在一条长度为arcs[i][j]的路径,该路径不一定是最短路径,尚需进行n次试探. 首先考虑路径(vi, v0, ...

  2. 最短路径(Floyd算法)(c/c++)

    如果要得到图中各个顶点之间的最短路径,方法1:可以对每一个顶点采用Dijkstra算法:方法2:可以采用Floyd算法,它是一种用来求双源点之间最短路径的算法,采用邻接矩阵来存储图 辅助结构 int ...

  3. 【最短路径Floyd算法详解推导过程】看完这篇,你还能不懂Floyd算法?还不会?...

    简介 Floyd-Warshall算法(Floyd-Warshall algorithm),是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法,与Dijkstra算法类似.该算法名称以 ...

  4. 最短路径——Floyd算法及优化(蓝桥杯试题集)

    *对最短路径问题以及floyd算法.Dijkstra算法不是很理解的同学请移步前几篇博客~ 题目链接: http://lx.lanqiao.cn/problem.page?gpid=T15 问题描述 ...

  5. 最短路径——Floyd算法HDU Today(hdu2112)

    最短路径问题是图论研究中的一个经典算法问题, 旨在寻找图(由结点和路径组成的)中两结点之间的最短路径. 算法具体的形式包括: 确定起点的最短路径问题 - 即已知起始结点,求最短路径的问题. 确定终点的 ...

  6. HDU2066 一个人的旅行【最短路径+Floyd算法】

    一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  7. 求最短路径Floyd算法的并行化(解APSP问题)

    求最短路径的串行算法在互联网上应该一搜一大堆,也非常简单,几行代码搞定.但Floyd的并行算法却很难搜到,github倒是有一些,但不容易运行成功,这里对这个算法的并行化进行详细的讲解,结合论文以及实 ...

  8. 多源最短路径--Floyd算法

    #include<iostream> #include<cstdio> using namespace std; const int INF = 0x3f3f3f3f; int ...

  9. 最短路径——Floyd算法

    1. 背景: Floyd算法又称为插点法,是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法,与Dijkstra算法类似.该算法名称以创始人之一.1978年图灵奖获得者.斯坦福大学计算 ...

最新文章

  1. 进程和线程的区别与联系
  2. kafka channle的应用案例
  3. 显示Linux系统执行的进程
  4. Android之文件读写
  5. 性能与可靠性:Java应用为何像F1汽车
  6. c++如何使用json配置文件
  7. 安装插件报错:error: Microsoft Visual C++ 14.0 is required...
  8. selenium常用方法
  9. NET中对象的构建过程
  10. [LeetCode] 125. Valid Palindrome Java
  11. OpenLayers自定义投影,转换OpenLayers中加载的OSM的默认投影坐标
  12. Linux 内核/sys 文件系统之sysfs 属性文件
  13. linux 水印软件下载,水印美图滤镜相机
  14. 仿照支付宝等——自动获取短信中的验证码
  15. php正则判断是否为图片格式,JS 获取文件后缀,判断文件类型(比如是否为图片格式)...
  16. 红米Note5官方刷机日记 - 小米助手Recovery刷机
  17. Netty傻瓜教程(四):bossGroup, workGroup?
  18. 二进制转bcd码c语言程序,二进制转8421BCD码的算法
  19. 使用Proxmox 和 Deskpool 搭建桌面云系统
  20. Digispark ATTINY85 Arduino IDE 开发

热门文章

  1. android照片编辑软件,照片编辑免费软件下载-照片编辑软件app下载 v7.45最新版_5577安卓网...
  2. keepalived安装与配置_Nginx_Keepalived高可用配置
  3. C++定时器的实现之格式修订版
  4. 如何优雅地检测类型/表达式有效性?
  5. 今晚课题:2019-3-22
  6. 计算机网络教学方式探讨论文,学生老师论文,关于关于高中计算机网络教学效率提升相关参考文献资料-免费论文范文...
  7. python邮件发送哪个好_python发邮件(一)
  8. python选项卡中文详细说明_pycharm窗口选项卡管理
  9. 随机森林的特征 是放回抽样么_机器学习超详细实践攻略(10):随机森林算法详解及小白都能看懂的调参指南...
  10. OneNote使用说明