题目链接http://poj.org/problem?id=1125
首先,题目可能有多组测试数据,每个测试数据的第一行为经纪人数量N(当N=0时, 输入数据结束),然后接下来N行描述第i(1<=i<=N)个经纪人与其他经纪人的关系 (教你如何画图)。每行开头数字M为该行对应的经纪人有多少个经纪人朋友(该节点 的出度,可以为0),然后紧接着M对整数,每对整数表示成a,b,则表明该经纪人向第a 个经纪人传递信息需要b单位时间(即第i号结点到第a号结点的孤长为b),整张图为 有向图,即弧Vij 可能不等于弧Vji(数据很明显,这里是废话)。当构图完毕后,求 当从该图中某点出发,将“消息”传播到整个经纪人网络的最小时间,输出这个经纪 人号和最小时间。最小时间的判定方式为——从这个经纪人(结点)出发,整个经纪 人网络中最后一个人接到消息的时间。如果有一个或一个以上经纪人无论如何无法收 到消息,输出“disjoint”(有关图的连通性,但是这题数据很水,我这里没有判断连通)。
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <algorithm>
#include <map>
#include <vector>
#define ll long long
using namespace std;
const int inf=0x3f3f3f3f;
const int maxn=105;
int mp[maxn][maxn];
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
if(n==0)break;
int m;
memset(mp,inf,sizeof(mp));
for(int i=1;i<=n;i++){
scanf("%d",&m);
while(m--)
{
int u,v;
scanf("%d%d",&u,&v);
mp[i][u]=v;
}
}
for(int k=1;k<=n;k++)
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(mp[i][j]>mp[i][k]+mp[k][j])
mp[i][j]=mp[i][k]+mp[k][j];
int tmp,ans=inf,t;
for(int i=1;i<=n;i++){
tmp=0;
for(int j=1;j<=n;j++){
if(i==j)continue;
tmp=max(tmp,mp[i][j]);
}
if(ans>tmp)ans=tmp,t=i;
}
if(ans==inf)printf("disjoint\n");
else printf("%d %d\n",t,ans);
}
return 0;
}