poj1125-最短路-floyd

题目链接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;
}

猜你喜欢

转载自blog.csdn.net/qq_41568836/article/details/81382082
今日推荐