最短路径--Floyd-Warshall算法
第一行输入n和m
n代表有n个城市,m代表有m条道路,并且是单向路
输出一个n*n的矩阵,表示从任意一个城市到其他城市的最短路径
样例输入:
4 8
1 2 2
1 3 6
1 4 4
2 3 3
3 1 7
3 4 1
4 1 5
4 3 12
样例输出:
0 2 5 4
9 0 3 4
6 8 0 1
5 7 10 0
第一行输入n和m
n代表有n个城市,m代表有m条道路,并且是单向路
输出一个n*n的矩阵,表示从任意一个城市到其他城市的最短路径
样例输入:
4 8
1 2 2
1 3 6
1 4 4
2 3 3
3 1 7
3 4 1
4 1 5
4 3 12
样例输出:
0 2 5 4
9 0 3 4
6 8 0 1
5 7 10 0
Floyd-Warshall算法代码如下:
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int main()
{
int a[102][102]={0};
int n,m,k;
int inf=99999999;
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(i==j)a[i][j]=0;
else a[i][j]=inf;
}
}
int t1,t2,t3;
for(int i=0;i<m;i++){
scanf("%d%d%d",&t1,&t2,&t3);
a[t1][t2]=t3;
}
//下面就是floyd-warshall算法
for(int k=1;k<=n;k++){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(a[i][k]<inf&&a[k][j]<inf&&a[i][j]>a[i][k]+a[k][j]){
a[i][j]=a[i][k]+a[k][j];
}
}
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cout<<a[i][j]<<" ";
}
cout<<endl;
}
return 0;
}