Main » 2011 » November » 7 » 奶牛的聚会(解题报告+原程)
6:07 PM
奶牛的聚会(解题报告+原程)

题目描述:
译: PaulInsider

N(1 ≤ N ≤ 1000)个农场中的每个农场都有一只奶牛去参加位于第X个农场的聚会.共有M (1 ≤ M ≤ 100,000)条单向的道路,每条道路连接一对农场.通过道路i会花费Ti (1 ≤ Ti ≤ 100)的时间.
作为参加聚会的奶牛必须走到聚会的所在地(农场X).当聚会结束时,还要返回各自的农场.奶牛都是很懒的,她们想找出花费时间最少的路线.由于道路都是单向的,所有她们前往农场X的路线可能会不同于返程的路线.
Of all the cows, what is the longest amount of time a cow must spend walking to the party and back? 对于所有参加聚会的奶牛,找出前往聚会和返程花费总时间最多的奶牛,输出这只奶牛花费的总时间.

输入格式:
第1行:三个用空格隔开的整数.
第2行到第M+1行,每行三个用空格隔开的整数:Ai, Bi,以及Ti.表示一条道路的起点,终点和需要花费的时间.

输出格式:
唯一一行:一个整数: 所有参加聚会的奶牛中,需要花费总时间的最大值.
样例输出:
4 8 2
1 2 4
1 3 2
1 4 7
2 1 1
2 3 5
3 1 2
3 4 4
4 2 3
样例输入:
10
样例说明:
共有4只奶牛参加聚会,有8条路,聚会位于第2个农场.
第4只奶牛可以直接到聚会所在地(花费3时间),然后返程路线经过第1和第3个农场(花费7时间),总共10时间.

题解:
很简单的最短路问题,不多解释了,相信很多人敲弗洛伊德的代码都很快,呵呵,只不过很慢,用SPFA,贝尔曼福德等等,呵呵,上代码!
原程:C++语言
made by PaulInsider!
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#define min(a,b) ((a)<=(b)?(a):(b))
using namespace std;
int n,m,mo;
int q[1001][1001];
int main()
{
    freopen ("sparty.in","r",stdin);
    freopen ("sparty.out","w",stdout);
    scanf("%d%d%d",&n,&m,&mo);
    for (int i=1;i<=n;i++)
    {
        for (int j=1;j<=n;j++)
        {
            q[i][j]=-1;
        }
    }
    for (int i=0;i<m;i++)
    {
        int a,b,c;
        scanf("%d%d%d",&a,&b,&c);
        q[a][b]=c;
    }
    for (int k=1;k<=n;k++)
    {
        for (int i=1;i<=n;i++)
        {
            for (int j=1;j<=n;j++)
            {
                if (q[i][k]!=-1&&q[k][j]!=-1)
                {
                    if (q[i][j]==-1)
                    {
                        q[i][j]=q[i][k]+q[k][j];
                    }
                    else
                    {
                        q[i][j]=min(q[i][j],q[i][k]+q[k][j]);
                       
                    }
                }
            }
        }
    }
    int answer=0;
    for (int i=1;i<=n;i++)
    {
        if (i==mo)
        {
            continue;
        }
        int temp;
        temp=q[i][mo]+q[mo][i];
        if (temp>answer)
        {
            answer=temp;
        }
    }
    cout<<answer;
    return 0;
}


神牛飘过,水牛留步!
ORZ CZB!
Views: 334 | Added by: dandan | Tags: NOIP | Rating: 0.0/0
Total comments: 1
1 Freddy  
0
SPFA 0.3秒不解釋~

現在正在學習STL PQ容器~

Name *:
Email *:
Code *: