zoukankan      html  css  js  c++  java
  • NYOJ-115 城市平乱

     

    城市平乱

    时间限制: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
    来源
    《世界大学生程序设计竞赛高级教程·第一册》改编
     
     1 #include <cstdio>
     2 #include <iostream>
     3 #include <cstring>
     4 
     5 using namespace std;
     6 const int INF = 0x3fffffff;
     7 
     8 int num[105], map[1005][1005];
     9 int n, m, p, q;
    10 
    11 int Dijkstra()
    12 {
    13     bool visit[1005];
    14     int dis[1005];
    15     for(int i = 1; i <= m; ++i)
    16     {
    17         visit[i] = false;
    18         dis[i] = map[q][i];
    19     }
    20     visit[q] = true;
    21     
    22     int min = INF;
    23     int k;
    24     for(int i = 1; i < m; ++i)
    25     {
    26         min = INF;
    27         k = 1;
    28         for(int j = 1; j <= m; ++j)
    29         {
    30             if(!visit[j] && dis[j] < min)
    31             {
    32                 min = dis[j];
    33                 k = j;
    34             }
    35         }
    36         visit[k] = true;
    37         for(int j = 1; j <= m; ++j)
    38         {
    39             if(!visit[j] && dis[k] + map[k][j] < dis[j])
    40             {
    41                 dis[j] = dis[k] + map[k][j];
    42             }
    43         }
    44     }
    45     
    46     min = INF;
    47     for(int i = 0; i < n; ++i)
    48     {
    49         if(min > dis[num[i]])
    50             min = dis[num[i]];
    51     }
    52     return min;
    53 }
    54 
    55 int main()
    56 {
    57     int T, a, b, len;
    58     scanf("%d", &T);
    59     while(T--)
    60     {
    61         scanf("%d%d%d%d", &n, &m, &p, &q);
    62         for(int i = 0; i < n; ++i)
    63             scanf("%d", &num[i]);
    64         for(int i = 1; i <= m; ++i)
    65             for(int j = 1; j < i; ++j)
    66                 map[i][j] = map[j][i] = INF;
    67                 
    68         while(p--)
    69         {
    70             scanf("%d%d%d", &a, &b, &len);
    71             if(map[a][b] > len)
    72                 map[a][b] = map[b][a] = len;
    73         }
    74         
    75         printf("%d
    ", Dijkstra());
    76     }
    77     return 0;
    78 }
  • 相关阅读:
    在CentOS7上部署OpenStack 步骤详解
    Linux运维工程师工作手册
    Nginx+Keepalived实现Web服务器负载均衡
    Django Nginx+uwsgi 安装配置
    Docker-搭建Docker Registry
    centos7系统默认防火墙Firewall使用方法
    Shell脚本编写及常见面试题(二)
    Shell脚本编写及常见面试题(一)
    Linux之解决每次git pull/git push都需输入密码设置
    基于thinkphp5的Excel上传
  • 原文地址:https://www.cnblogs.com/dongsheng/p/3162678.html
Copyright © 2011-2022 走看看