当前位置: 首页 > news >正文

win7用本地文件做网站模板滁州网站开发czesou

win7用本地文件做网站模板,滁州网站开发czesou,北京朝阳区租房,蛋糕店网站开发策划书适用情景Floyd算法适用于多源汇最短路,也就是他问你比如说从3号点到6号点的最短路距离,比如说从7号点到20号点的最短路距离,而不是单源最短路(从1号点到n号点的最短路距离)。在这个算法当中允许负权边的存在。但在求最…

适用情景

  1. Floyd算法适用于多源汇最短路,也就是他问你比如说从3号点到6号点的最短路距离,比如说从7号点到20号点的最短路距离,而不是单源最短路(从1号点到n号点的最短路距离)。在这个算法当中允许负权边的存在。但在求最短路距离当中(包括其他算法也一样)是不能够出现负环的,因为这样最短路距离可能变到负无穷去了


时间复杂度

  1. 三重无脑循环,显然O(N^3)。


算法解释

  1. 首先,对于Floyd算法来说,对于图的存储必须要用邻接矩阵来存,不能用邻接表。然后对于邻接矩阵,一开始当然得初始化,这边必须得注意:由于是图,这个矩阵无论是行还是列,有效位都是从一开始。

int dist[N][N];  //N表示图中点的个数+1
  1. 然后Floyd算法是允许这个图当中存在负权边,但是不能出现负环因为在最短路问题当中的话,一旦出现负环,最短路可能变成负无穷)。然后需要对dist数组初始化,这边再提一句:我们现在已经是默认图当中没有负环,好那么现在如果说存在自环的话,肯定是正的,在最短路当中那就不予考虑,于是在初始化的过程当中,如果说i等于j,直接就是0,其他的话就初始化成正无穷,为什么要正无穷?想想就知道了,等会儿我肯定需要min操作

for (int i=1;i<=n;i++)
{for (int j=1;j<=n;j++){if (i==j){dist[i][j]=0;}else{dist[i][j]=0x3f3f3f3f;}}
}
  1. 然后当往这个邻接矩阵当中去输入一条一条图当中的边的时候,由于我们现在是最短路问题,因此我们只需要取小的就可以了,然后如果是自环的话,所以我们默认是没有负环的,因此取小后就是0

while(m--)
{scanf("%d %d %d",&a,&b,&c);dist[a][b]=MIN(dist[a][b],c);
}
  1. 然后接下来就是执行Floyd算法,其实就是三重循环,外循环k从1到n,第二层循环i从1到n,第三层循环j从1到n。然后每一层循环的话就如下比较一下,至于原理的话,这个是与动态规划有关,像我现在的话也掌握不了,先把算法的步骤先记牢吧

for (int k=1;k<=n;k++)
{for (int i=1;i<=n;i++){for (int j=1;j<=n;j++){dist[i][j]=MIN(dist[i][j],dist[i][k]+dist[k][j]);}}
}
  1. 然后当这三重循环结束之后,原先dist数组是用来存边的,现在他已经像孙悟空变身一样,变成了从i到j的最短距离了。当然也有可能的情况就是从i到j的话是走不到的,这时候还谈个屁最短路啊,那如何去判断走不到的这种情况呢?由于是允许存在负权边的情况,因此当在更新的时候有可能会把这个无穷大的值稍微更新了小了一些,因此不能直接dist[ i ][ j ] 等于 0x3f3f3f3f

while(k--)
{scanf("%d %d",&a,&b);if(dist[a][b]>0x3f3f3f3f/2){printf("impossible\n");}else{printf("%d\n",dist[a][b]);}
}

例题

来源:AcWing

854. Floyd求最短路 - AcWing题库

#include <stdio.h>
#define N 210
#define MIN(a,b) ((a)<(b)?(a):(b))
int dist[N][N];
int main()
{int n,m,k,a,b,c;scanf("%d %d %d",&n,&m,&k);for (int i=1;i<=n;i++){for (int j=1;j<=n;j++){if (i==j){dist[i][j]=0;}else{dist[i][j]=0x3f3f3f3f;}}}while(m--){scanf("%d %d %d",&a,&b,&c);dist[a][b]=MIN(dist[a][b],c);}for (int k=1;k<=n;k++){for (int i=1;i<=n;i++){for (int j=1;j<=n;j++){dist[i][j]=MIN(dist[i][j],dist[i][k]+dist[k][j]);}}}while(k--){scanf("%d %d",&a,&b);if(dist[a][b]>0x3f3f3f3f/2){printf("impossible\n");}else{printf("%d\n",dist[a][b]);}}return 0;
}
http://www.yayakq.cn/news/885151/

相关文章:

  • 网站的建设方案怎么写南京网络维护公司
  • 张店网站建设哪家好久久建筑网平台
  • 高端定制网站建设制作3d建模怎么做网站旋转
  • 北京电子商务网站制作网页设计实训报告3篇
  • app手机网站模板国内付费代理ip哪个好
  • 网站排名优化平台深圳做个商城网站设计
  • 网站建设属什么资产wordpress 欢迎插件
  • 北京做公司网站公司苏州 营销型网站 高端网站
  • 商务网站管理的主要内容数据管理物流托运
  • 济南网站建设铭盛信息建站必须要域名吗
  • 网页设计与网站建设实战大全国外网站A
  • 凤翔网站开发推荐专业做网站公司
  • 湖南省城乡建设厅网站石碣镇网站仿做
  • 苏州建网站的公司平台收费标准友链出售
  • 郑州网站推广公司信息越秀区pc端网站建设
  • 高端个人网站教材资源网站建设
  • 网站建设所需的硬软件专业网站设计团队
  • 网站制作时百度文库首页官网
  • 网站建设内容与实现功能郑州优秀网站建设公司
  • 网站运行与维护wordpress调用置顶分类
  • 不让在建设门户网站邮箱企业邮箱入口
  • 建设网站域名有了还要什么佟年帮韩商言做网站是第几集
  • 云服务器可以做多个网站如何在百度做免费推广产品
  • 政务内网网站群建设app开发工具下载
  • 企业网站栏目结构你做的网站会不会被人模仿
  • 海外网站制作张雪峰谈工业设计
  • 免费网站安全软件下载wordpress架构
  • 网站图片的像素十大app开发公司
  • 和国外做贸易用什么网站湖南人文科技学院是几本
  • 如何做好网站手机网站 禁止缩放