C++怎么实现多源最短路径之Floyd算法

小编给大家分享一下C++怎么实现多源最短路径之Floyd算法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

我们提供的服务有:成都做网站、成都网站建设、微信公众号开发、网站优化、网站认证、西塞山ssl等。为上千余家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的西塞山网站制作公司

C++实现多源最短路径之Floyd算法,具体如下:

#include
#include
#include
#define MAX 999
using namespace std;
int n,m;
int e[MAX][MAX];
void Init()
{
  for(int i=1; i<=n; ++i)
    for(int j=1; j<=n; ++j)
    {
      if(i==j)
        e[i][j]=0;
      else
        e[i][j]=MAX;
    }
}
void Input()
{
  int a,b,c;
  for(int i=1; i<=m; ++i)
  {
    cin>>a>>b>>c;
    e[a][b]=c;
  }
}
void Floyd()
{
  for(int k=1; k<=n; k++)
    for(int i=1; i<=n; i++)
      for(int j=1; j<=n; j++)
        if(e[i][j]>e[i][k]+e[k][j])
          e[i][j]=e[i][k]+e[k][j];
}
void Output()
{
  for(int i=1; i<=n; ++i)
    for(int j=1; j<=n; ++j)
      cout<<"dis["<>n;
    if(!n) break;
    cout<<"m"<>m;
    Init();
    Input();
    Floyd();
    Output();
  }
}

Floyd算法是求多点最短路径的一种算法,其核心代码为

void Floyd()
{
  for(int k=1; k<=n; k++)
    for(int i=1; i<=n; i++)
      for(int j=1; j<=n; j++)
        if(e[i][j]>e[i][k]+e[k][j])
          e[i][j]=e[i][k]+e[k][j];
}

看完了这篇文章,相信你对“C++怎么实现多源最短路径之Floyd算法”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


本文题目:C++怎么实现多源最短路径之Floyd算法
分享网址:http://bzwzjz.com/article/gsdhdp.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都商城网站建设 成都网站设计 成都网站建设 成都网站设计 成都企业网站制作 成都企业网站建设 成都响应式网站建设 成都网站建设 温江网站设计 上市集团网站建设 网站建设推广 企业手机网站建设 H5网站制作 成都网站制作 攀枝花网站设计 网站制作报价 重庆网站制作 网站制作 成都网站设计 成都网站制作 成都网站制作 营销型网站建设