题目

来源
思路
多源最短路径问题,直接使用Floyd算法,思路简单,代码也好写。注意初始化,以及一些小细节,比如如果INT_MAX,因为相加之后会出现溢出。其余详见代码。
关于floyd,详见这篇blog:(建议收藏)一文多图,彻底搞懂Floyd算法(多源最短路径)-阿里云开发者社区
代码
cpp
#include<bits/stdc++.h>
using namespace std;
const int N=110;
int d[N][N];
int n,m;
void floyd(){
for(int k=1;k<=n;k++){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
}
}
}
}
int main(){
while(cin>>n>>m){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
d[i][j]=INT_MAX/2;
}
}
int i,j,l;
while(m--){
cin>>i>>j>>l;
d[i][j]=l;
d[j][i]=l;
}
for(int i=1;i<=n;i++)d[i][i]=0;
floyd();
int x,y;
cin>>x>>y;
if(d[x][y]==INT_MAX/2)cout<<"No path"<<endl;
else cout<<d[x][y]<<endl;
}
return 0;
}