HHUOJ 1652 算法7-16 弗洛伊德最短路径算法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了HHUOJ 1652 算法7-16 弗洛伊德最短路径算法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1631字,纯文字阅读大概需要3分钟。
内容图文
![HHUOJ 1652 算法7-16 弗洛伊德最短路径算法](/upload/InfoBanner/zyjiaocheng/739/3f940e8197c64de594a2fa186ab669bf.jpg)
HHUOJ 1652 算法7-16 弗洛伊德最短路径算法
题目描述
在带权有向图G中,求G中的任意一对顶点间的最短路径问题,也是十分常见的一种问题。
解决这个问题的一个方法是执行n次迪杰斯特拉算法,这样就可以求出每一对顶点间的最短路径,执行的时间复杂度为O(n3)。
而另一种算法是由弗洛伊德提出的,时间复杂度同样是O(n3),但算法的形式简单很多。
可以将弗洛伊德算法描述如下:
在本题中,读入一个有向图的带权邻接矩阵(即数组表示),建立有向图并按照以上描述中的算法求出每一对顶点间的最短路径长度。
输入
输入的第一行包含1个正整数n,表示图中共有n个顶点。其中n不超过50。
以后的n行中每行有n个用空格隔开的整数。对于第i行的第j个整数,如果大于0,则表示第i个顶点有指向第j个顶点的有向边,且权值为对应的整数值;如果这个整数为0,则表示没有i指向j的有向边。当i和j相等的时候,保证对应的整数为0。
输出
共有n行,每行有n个整数,表示源点至每一个顶点的最短路径长度。如果不存在从源点至相应顶点的路径,输出-1。对于某个顶点到其本身的最短路径长度,输出0。
请在每个整数后输出一个空格,并请注意行尾输出换行。
样例输入
4 0 3 0 1 0 0 4 0 2 0 0 0 0 0 1 0
样例输出
0 3 2 1 6 0 4 7 2 5 0 3 3 6 1 0
floyd算法模板题:
#include<bits/stdc++.h>
#define inf 1e9
#define maxn 200
using namespace std;
int dis[maxn][maxn];
int n,k;
void floyd()
{
for(int k=0;k<n;k++)
{
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if(dis[i][k]!=inf && dis[k][j]!=inf && dis[i][k]+dis[k][j]<dis[i][j])
{
dis[i][j]=dis[i][k]+dis[k][j];
}
}
}
}
}
int main()
{
scanf("%d",&n);
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
scanf("%d",&k);
if(k) dis[i][j]=k;
else dis[i][j]=inf;
}
}
floyd();
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if (i==j) printf("0 ");
else if(dis[i][j]==inf) printf("-1 ");
else printf("%d ",dis[i][j]);
}
puts("");
}
return 0;
}
内容总结
以上是互联网集市为您收集整理的HHUOJ 1652 算法7-16 弗洛伊德最短路径算法全部内容,希望文章能够帮你解决HHUOJ 1652 算法7-16 弗洛伊德最短路径算法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。