题意:求出两点之间所有路径最大权值的最小值。
思路:转变一下Floyd的形式即可;
注意:注意初始化问题,还有UVA奇葩的输出形式。
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<map>
using namespace std;
#define inf 0x3f3f3f
int dp[][];
int main()
{
int n,m,q,a,b,w,ca = ;
while(cin>>n>>m>>q)
{
if(n+m+q==) break;
if(ca != )printf("\n");
memset(dp,0x3f,sizeof(dp));
for(int i = ; i < m; i++)
{
cin>>a>>b>>w;
dp[a][b] = dp[b][a] = w;
}
for(int i = ; i <= n; i++)
{
dp[i][i] = ;
}
for(int k = ; k <= n; k++)
{
for(int i = ; i <= n; i++)
{
for(int j = ; j <= n; j++)
{
dp[i][j] = min(dp[i][j],max(dp[i][k],dp[k][j]));
}
}
}
cout<<"Case #"<<++ca<<endl;
for(int i = ; i < q; i++)
{
cin>>a>>b;
if(dp[a][b] >= inf)
{
cout<<"no path\n";
}
else cout<<dp[a][b]<<endl;
}
}
return ;
}