首页 > 其他 > 详细

nyoj 115 城市平乱

时间:2017-06-20 09:16:30      阅读:281      评论:0      收藏:0      [点我收藏+]

城市平乱

时间限制:1000 ms  |  内存限制:65535 KB

难度:4

描述

南将军统领着N个部队,这N个部队分别驻扎在N个不同的城市。

他在用这N个部队维护着M个城市的治安,这M个城市分别编号从1到M。

现在,小工军师告诉南将军,第K号城市发生了暴乱,南将军从各个部队都派遣了一个分队沿最近路去往暴乱城市平乱。

现在已知在任意两个城市之间的路行军所需的时间,你作为南将军麾下最厉害的程序员,请你编写一个程序来告诉南将军第一个分队到达叛乱城市所需的时间。

 

注意,两个城市之间可能不只一条路。

输入

第一行输入一个整数T,表示测试数据的组数。(T<20)
每组测试数据的第一行是四个整数N,M,P,Q(1<=N<=100,N<=M<=1000,M-1<=P<=100000)其中N表示部队数,M表示城市数,P表示城市之间的路的条数,Q表示发生暴乱的城市编号。
随后的一行是N个整数,表示部队所在城市的编号。
再之后的P行,每行有三个正整数,a,b,t(1<=a,b<=M,1<=t<=100),表示a,b之间的路如果行军需要用时为t

数据保证暴乱的城市是可达的。

输出

对于每组测试数据,输出第一支部队到达叛乱城市时的时间。每组输出占一行

样例输入

1

3 8 9 8

1 2 3

1 2 1

2 3 2

1 4 2

2 5 3

3 6 2

4 7 1

5 7 3

5 8 2

6 8 2

样例输出

4

 
#include <cstdio>
#include <iostream>
#include <cstring>

using namespace std;
const int INF = 0x3fffffff;

int num[105], map[1005][1005];
int n, m, p, q;

int Dijkstra()
{
    bool visit[1005];
    int dis[1005];
    for(int i = 1; i <= m; ++i)
    {
        visit[i] = false;
        dis[i] = map[q][i];
    }
    visit[q] = true;
    
    int min = INF;
    int k;
    for(int i = 1; i < m; ++i)
    {
        min = INF;
        k = 1;
        for(int j = 1; j <= m; ++j)
        {
            if(!visit[j] && dis[j] < min)
            {
                min = dis[j];
                k = j;
            }
        }
        visit[k] = true;
        for(int j = 1; j <= m; ++j)
        {
            if(!visit[j] && dis[k] + map[k][j] < dis[j])
            {
                dis[j] = dis[k] + map[k][j];
            }
        }
    }
    
    min = INF;
    for(int i = 0; i < n; ++i)
    {
        if(min > dis[num[i]])
            min = dis[num[i]];
    }
    return min;
}

int main()
{
    int T, a, b, len;
    scanf("%d", &T);
    while(T--)
    {
        scanf("%d%d%d%d", &n, &m, &p, &q);
        for(int i = 0; i < n; ++i)
            scanf("%d", &num[i]);
        for(int i = 1; i <= m; ++i)
            for(int j = 1; j <=m; ++j)
                map[i][j] = map[j][i] = INF;
                
        while(p--)
        {
            scanf("%d%d%d", &a, &b, &len);
            if(map[a][b] > len)
                map[a][b] = map[b][a] = len;
        }
        
        printf("%d\n", Dijkstra());
    }
    return 0;
}        

  

nyoj 115 城市平乱

原文:http://www.cnblogs.com/zhangliu/p/7052615.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!