百度百科定义:传送门

一、floyd算法

说实话这个算法是用来求多源最短路径的算法。

算法原理:

1,从任意一条单边路径开始。所有两点之间的距离是边的权,如果两点之间没有边相连,则权为无穷大。
2,对于每一对顶点 u 和 v,看看是否存在一个顶点 w 使得从 u 到 w 再到 v 比已知的路径更短。如果是更新它。
把图用邻接矩阵G表示出来,如果从Vi到Vj有路可达,则G[i][j]=d,d表示该路的长度;否则G[i][j]=无穷大。定义一个矩阵D用来记录所插入点的信息,D[i][j]表示从Vi到Vj需要经过的点,初始化D[i][j]=j。把各个顶点插入图中,比较插点后的距离与原来的距离,G[i][j] = min( G[i][j], G[i][k]+G[k][j] ),如果G[i][j]的值变小,则D[i][j]=k。在G中包含有两点之间最短道路的信息,而在D中则包含了最短通路径的信息。

  1. typedef long long int lli;
  2. lli map[][];
  3. int n;
  4.  
  5. void floyd()
  6. {
  7. for (register int i=;i<=n;i++)
  8. for (register int j=;j<=n;j++)
  9. for (register int k=;k<=n;k++)
  10. if (map[i][j]>map[i][k]+map[k][j])
  11. map[i][j]=map[i][k]+map[k][j];
  12. }

最后程序中的map[i][j]就是i->j的最短路径长度。

时间复杂度:O(n3),空间复杂度:S(n2)(用的是邻接矩阵)。

所以一般要用这种算法的题数据范围都会很小(1000的三次方就十亿了,你说呢)

洛谷P1744 采购特价

显然是floyd的板子题

光从n<=100的数据范围就能看出来......

代码:

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cstdlib>
  4. #include<iomanip>
  5. #include<cmath>
  6. #include<cstring>
  7. #include<string>
  8. #include<algorithm>
  9. #include<time.h>
  10. #include<queue>
  11. using namespace std;
  12. typedef long long ll;
  13. typedef long double ld;
  14. typedef pair<int,int> pr;
  15. const double pi=acos(-);
  16. #define rep(i,a,n) for(int i=a;i<=n;i++)
  17. #define per(i,n,a) for(int i=n;i>=a;i--)
  18. #define Rep(i,u) for(int i=head[u];i;i=Next[i])
  19. #define clr(a) memset(a,0,sizeof a)
  20. #define pb push_back
  21. #define mp make_pair
  22. #define fi first
  23. #define sc second
  24. ld eps=1e-;
  25. ll pp=;
  26. ll mo(ll a,ll pp){if(a>= && a<pp)return a;a%=pp;if(a<)a+=pp;return a;}
  27. ll powmod(ll a,ll b,ll pp){ll ans=;for(;b;b>>=,a=mo(a*a,pp))if(b&)ans=mo(ans*a,pp);return ans;}
  28. ll read(){
  29. ll ans=;
  30. char last=' ',ch=getchar();
  31. while(ch<'' || ch>'')last=ch,ch=getchar();
  32. while(ch>='' && ch<='')ans=ans*+ch-'',ch=getchar();
  33. if(last=='-')ans=-ans;
  34. return ans;
  35. }//head
  36.  
  37. int n,m,s,t;
  38. double a[][],dis[][];
  39.  
  40. int main()
  41. {
  42. n=read();
  43. rep(i,,n)
  44. a[i][]=read(),a[i][]=read();
  45. memset(dis,0x7f,sizeof(dis));
  46. int x,y;
  47. m=read();
  48. rep(i,,m)
  49. {
  50. x=read(),y=read();
  51. dis[y][x]=dis[x][y]=sqrt(pow(a[x][]-a[y][],)+pow(a[x][]-a[y][],));
  52. }
  53. s=read(),t=read();
  54. rep(k,,n)
  55. rep(i,,n)
  56. rep(j,,n)
  57. {
  58. if((i!=j&&i!=k&&j!=k&&dis[i][j]>dis[i][k]+dis[k][j])
  59. dis[i][j]=dis[i][k]+dis[k][j];
  60. }
  61. printf("%.2lf",dis[s][t]);
  62. return ;
  63. }

Floyd算法——计算图中任意两点之间的最短路径的更多相关文章

  1. Geotools求shapefile路网中任意两点之间最短路径的距离

    前言:之前在博问求助过这个问题.经过几天的思考,算是解决了(但仍有不足),另一方面对Geotools不是很熟,有些描述可能不正确,希望大家批评指正. 问题:作为一个新手,我并没有发现Geotools中 ...

  2. POJ 3660 Cow Contest 任意两点之间的关系 Floyd

    题意:牛之间有绝对的强弱,给出一些胜负关系,问有多少头牛可以确定其绝对排名. #include <iostream> #include <cstdio> #include &l ...

  3. javascript实现有向无环图中任意两点最短路径的dijistra算法

    有向无环图 一个无环的有向图称做有向无环图(directed acycline praph).简称DAG 图.DAG 图是一类较有向树更一般的特殊有向图, dijistra算法 摘自 http://w ...

  4. Floyd-Warshall求图中任意两点的最短路径

    原创 除了DFS和BFS求图中最短路径的方法,算法Floyd-Warshall也可以求图中任意两点的最短路径. 从图中任取两点A.B,A到B的最短路径无非只有两种情况: 1:A直接到B这条路径即是最短 ...

  5. 2D和3D空间中计算两点之间的距离

    自己在做游戏的忘记了Unity帮我们提供计算两点之间的距离,在百度搜索了下. 原来有一个公式自己就写了一个方法O(∩_∩)O~,到僵尸到达某一个点之后就向另一个奔跑过去 /// <summary ...

  6. dfs+记忆化搜索,求任意两点之间的最长路径

    C.Coolest Ski Route 题意:n个点,m条边组成的有向图,求任意两点之间的最长路径 dfs记忆化搜索 #include<iostream> #include<stri ...

  7. AOJ GRL_1_C: All Pairs Shortest Path (Floyd-Warshall算法求任意两点间的最短路径)(Bellman-Ford算法判断负圈)

    题目链接:http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_1_C All Pairs Shortest Path Input ...

  8. poj2762 判断一个图中任意两点是否存在可达路径 也可看成DAG的最小覆盖点是否为1

      Going from u to v or from v to u? Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 179 ...

  9. 百度地图api文档实现任意两点之间的最短路线规划

    两个点之间的路线是使用“Marker”点连接起来的,目前还没找到改变点颜色的方法,测试过使用setStyle没有效果. <html><head> <meta http-e ...

随机推荐

  1. 智能化CRM客户关系管理系统介绍一

    智能化CRM客户关系管理系统介绍一 CRM客户关系管理的定义是:企业为提高核心竞争力,利用相应的信息技术以及互联网技术来协调企业与顾客间在销售.营销和服务上的交互,从而提升其管理方式,向客户提供创新式 ...

  2. Monkey测试记录

    配置环境变量,不然用不了adb命令 path这里也一样配置一下 命令的各种意思百度一下看看也就知道了 看到一篇博客推荐的一种测试命令,我也直接拿来用了 adb shell monkey -p 你的包名 ...

  3. 对象的使用处理,作用域的和ajax中this的理解

    首先,封装类,理解清楚你需要用的哪几个变量,然后声明,然后在类里封装函数,其中,constructor就是存放初始变量的地方. 这里还是datatable的处理解决, constructor(tabl ...

  4. 用 Heapster 监控集群 - 每天5分钟玩转 Docker 容器技术(176)

    Heapster 是 Kubernetes 原生的集群监控方案.Heapster 以 Pod 的形式运行,它会自动发现集群节点.从节点上的 Kubelet 获取监控数据.Kubelet 则是从节点上的 ...

  5. DataReader的使用

    public List<Student> GetList()        {            string sql = "select * from Student&qu ...

  6. Docker 架构(二)【转】

    Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器. Docker 容器通过 Docker 镜像来创建. 容器与镜像的关系类似于面向对象编程中的对象与类 ...

  7. 启动期间的内存管理之初始化过程概述----Linux内存管理(九)

    在内存管理的上下文中, 初始化(initialization)可以有多种含义. 在许多CPU上, 必须显式设置适用于Linux内核的内存模型. 例如在x86_32上需要切换到保护模式, 然后内核才能检 ...

  8. 2星|《重新定义物流》:形式像PPT,内容像公关稿

    全书彩印,彩图大概占一半篇幅,感觉是把一些PPT配上点说明拼成了一本书.前后的彩图风格差异较大,大部分给我的感觉都是堆砌名词术语的官方宣传材料,少部分色调单一形式简单的图,像是作者们自己绘制的,反而能 ...

  9. ipa企业签名

    包天包周包月季度包年套餐_app/ios应用企业签名_ios企业签名 常见问题 需要提供 App 的源码吗? 不需要源码,只发 ipa 或者 app 格式的安装包即可. 客户怎么安装签名好的软件? 安 ...

  10. 黏包现象之udp

    老师的博客:http://www.cnblogs.com/Eva-J/articles/8244551.html server端 import socket import subprocess ser ...