题意:求这n个点中到另外n-1个点的最短路的最大值
思路:floyed算法跑一遍,得出任意两点的最短路,再筛一遍就可以了
#include<iostream>
#include<algorithm>
#include<math.h>
#include<string.h>
using namespace std;
int n,m;
const int N=1000;
int dist[N][N];
int s[N][N];
void init()
{
memset(dist,0x3f3f3f,sizeof(dist));
for(int i=1;i<=n;i++)
{
dist[i][i]=0;
}
}
void floyed()
{
for(int k=1;k<=n;k++)
{
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
dist[i][j]=min(dist[i][j],dist[i][k]+dist[k][j]);
}
}
}
int min1=0x3f3f3f3f;
int idx;
for(int i=1;i<=n;i++)
{
int max1=0;
for(int j=1;j<=n;j++)
{
max1=max(max1,dist[i][j]);
}
if(min1>max1)
{
idx=i;
min1=max1;
}
}
cout<<idx<<" "<<min1<<endl;
}
int main()
{
while(cin>>n&&n!=0)
{
init();
for(int i=1;i<=n;i++)
{
cin>>m;
for(int j=1;j<=m;j++)
{
int a,b;
cin>>a>>b;
dist[i][a]=b;
}
}
floyed();
}
}