nyoj 115
来源:互联网 发布:迪拜购物 知乎 编辑:程序博客网 时间:2024/04/30 02:16
城市平乱
时间限制: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<bits/stdc++.h>using namespace std;const int MAXN=0x7fffffff;int buduinum[105];int G[1005][1005];int dist[1005];void dijkstar(int v0,int n){ int bj[1005]; memset(bj,0,sizeof(bj)); memset(dist,0,sizeof(dist)); for(int i=1;i<=n;i++){ dist[i]=G[v0][i]; } bj[v0]=1; for(int i=2;i<=n;i++){ int mins=MAXN; int u=v0; for(int j=1;j<=n;j++){ if(!bj[j]&&dist[j]<mins){ u=j; mins=dist[j]; } } bj[u]=1; for(int j=1;j<=n;j++){ if(!bj[j]&&G[u][j]<MAXN){ if(dist[u]+G[u][j]<dist[j]){ dist[j]=dist[u]+G[u][j]; } } } }}int main(){ int T; scanf("%d",&T); while(T--){ for(int i=0;i<1005;i++){ for(int j=0;j<1005;j++){ if(i==j) G[i][j]=0; else G[i][j]=MAXN; } } int N,M,P,Q,maxs=0; scanf("%d%d%d%d",&N,&M,&P,&Q); for(int i=0;i<N;i++) scanf("%d",&buduinum[i]); for(int i=0;i<P;i++){ int u,v,t; scanf("%d%d%d",&u,&v,&t); if(G[u][v]>t){ G[u][v]=G[v][u]=t; } maxs=max(maxs,max(u,v)); } int mins=MAXN; for(int i=0;i<N;i++){ dijkstar(buduinum[i],maxs); mins=min(mins,dist[Q]); } printf("%d\n",mins); } return 0;}
0 0
- nyoj 115
- nyoj 115
- nyoj 115 城市平乱
- nyoj 115 Dijkstra
- nyoj-115-城市平乱
- nyoj 115 城市平乱
- NYOJ 115 城市平乱
- NYOJ 115 城市平乱
- NYOJ-115 城市平乱
- nyoj 115 城市平乱
- NYOJ 115 城市平乱
- nyoj 115 城市平乱
- nyoj 115 城市平乱
- nyoj 115 城市平乱
- NYOJ 115 城市平乱
- nyoj 115 dijkstra
- NYOJ 115 城市平乱
- NYOJ 115 Dijstra入门
- ValidateUtil by Annotation and HibernateImplements
- 从零认识tomcat,构建一机多实例tomcat集群
- java中的==、equals()、hashCode()源码分析
- Oracle异常 创建并抛出命名的自定义异常
- 模拟搭建Web项目的真实运行环境(四)
- nyoj 115
- Uubntu安装wps详细教程
- zurmo(五)-自定义语言(2)
- RpcMonitorFilter——monitor dubbo by filter
- 12.6--12.18北漂前2周点滴生活
- 探寻暗网
- 菜鸟学Android源码-Android System StartUp Process
- 树状数组板子
- 机器人相关资源