AcWing 854. Floyd求最短路
原题链接
简单
作者:
术
,
2021-01-23 16:30:54
,
所有人可见
,
阅读 248
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=205,INF=1e9;
int n,m,k;
int d[N][N];
int floyd(){
for(int z=1;z<=n;z++){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
d[i][j]=min(d[i][j],d[i][z]+d[z][j]);
}
}
}
}
int main()
{
cin>>n>>m>>k;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)
if(i==j) d[i][j]=0;
else d[i][j]=INF;
}
for(int i=0;i<m;i++)
{
int a,b,c;
cin>>a>>b>>c;
d[a][b]=min(c,d[a][b]);//min
}
floyd();
while(k--){
int a,b;
cin>>a>>b;
if(d[a][b]>INF/2)
cout<<"impossible"<<endl;
else
cout<<d[a][b]<<endl;
}
//cout << "Hello world!" << endl;
return 0;
}