题目
才20分
代码:
#include<bits/stdc++.h>
using namespace std;
long long n,m,u,v,w,f[101][101];
int main(){
memset(f,0x7f,sizeof(f));
scanf("%lld%lld",&n,&m);
for(int i=1;i<=m;i++){
scanf("%lld%lld%lld",&u,&v,&w);
f[u][v]=min(f[u][v],w);
f[v][u]=min(f[v][u],w);
}
for(int i=1;i<=n;i++){
f[i][i]=0;
}
for(int k=1;k<=n;k++){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if((i!=j)&&(j!=k)&&(k!=i)&&f[i][k]+f[k][j]<f[i][j]){
f[i][j]=f[i][k]+f[k][j];
}
}
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
printf("%lld ",f[i][j]);
}
printf("\n");
}
return 0;
}