题意:有N个点,两个人,其中一个人住在点1,另一个人住在点n,有M个点集,集合内的数表示任意两点的距离为dis ,现在问,如果两个人要见面,

需要最短距离是多少,有哪几个点能被当成见面点。

析:分别对1和n进行最短路操作,这个题最让人别扭的就是边太多,如果你直接全部都存下来,那么一定会MLE,所以一定要优化边。所以我们要把每一行的边都记下来,

而不是两两都记下,然后把每一行的编号记下来,最后要查询时,就行编号去定位到哪一行,这样就不会超内存。这里会了,其他的就很简单了。

代码如下:

  1. #pragma comment(linker, "/STACK:1024000000,1024000000")
  2. #include <cstdio>
  3. #include <string>
  4. #include <cstdlib>
  5. #include <cmath>
  6. #include <iostream>
  7. #include <cstring>
  8. #include <set>
  9. #include <queue>
  10. #include <algorithm>
  11. #include <vector>
  12. #include <map>
  13. #include <cctype>
  14. #include <stack>
  15. using namespace std;
  16.  
  17. typedef long long LL;
  18. typedef pair<int, int> P;
  19. const int INF = 0x3f3f3f3f;
  20. const double inf = 0x3f3f3f3f3f3f;
  21. const LL LNF = 100000000000000000;
  22. const double PI = acos(-1.0);
  23. const double eps = 1e-8;
  24. const int maxn = 1e5 + 5;
  25. const int mod = 1e9 + 7;
  26. const char *mark = "+-*";
  27. const int dr[] = {-1, 0, 1, 0};
  28. const int dc[] = {0, 1, 0, -1};
  29. int n, m;
  30. inline bool is_in(int r, int c){
  31. return r >= 0 && r < n && c >= 0 && c < m;
  32. }
  33. inline LL Max(LL a, LL b){ return a < b ? b : a; }
  34. inline LL Min(LL a, LL b){ return a > b ? b : a; }
  35. vector<int> G[maxn];
  36. vector<int> b[maxn];
  37. LL d1[maxn];
  38. LL d2[maxn];
  39. int t[maxn];
  40. bool vis[maxn];
  41.  
  42. void dijstra(int s, LL* d){
  43. priority_queue<P, vector<P>, greater<P> > pq;
  44. pq.push(P(0, s));
  45. memset(vis, false, sizeof vis);
  46. fill(d, d+n+1, LNF);
  47. d[s] = 0;
  48.  
  49. while(!pq.empty()){
  50. P p = pq.top(); pq.pop();
  51. int u = p.second;
  52. if(d[u] < p.first) continue;
  53. for(int i = 0; i < b[u].size(); ++i){//从编号找出在哪行
  54. int v = b[u][i];
  55. if(vis[v]) continue;
  56. vis[v] = true;
  57. for(int j = 0; j < G[v].size(); ++j){
  58. int uv = G[v][j], w = t[v];
  59. if(d[uv] > d[u] + w){
  60. d[uv] = d[u] + w;
  61. pq.push(P(d[uv], uv));
  62. }
  63. }
  64. }
  65. }
  66. }
  67.  
  68. int main(){
  69. int T; cin >> T;
  70. for(int kase = 1; kase <= T; ++kase){
  71. scanf("%d %d", &n, &m);
  72. for(int i = 1; i <= n; ++i) G[i].clear(), b[i].clear();
  73. for(int i = 1; i <= m; ++i){
  74. int k;
  75. scanf("%d %d", &t[i], &k);
  76. for(int j = 0; j < k; ++j){
  77. int v;
  78. scanf("%d", &v);
  79. G[i].push_back(v);//存边
  80. b[v].push_back(i);//记下行号
  81. }
  82. }
  83.  
  84. dijstra(1, d1);
  85. dijstra(n, d2);
  86. printf("Case #%d: ", kase);
  87. LL ans = LNF;
  88. for(int i = 1; i <= n; ++i)
  89. ans = Min(ans, Max(d1[i], d2[i]));
  90. if(ans == LNF) puts("Evil John");
  91. else{
  92. printf("%I64d\n", ans);
  93. int cnt = 0;
  94. for(int i = 1; i <= n; ++i)
  95. if(ans == Max(d1[i], d2[i])){
  96. if(cnt) putchar(' ');
  97. printf("%d", i);
  98. ++cnt;
  99. }
  100. printf("\n");
  101. }
  102. }
  103. return 0;
  104. }

  

HDU 5521 Meeting (最短路,dijstra)的更多相关文章

  1. HDU 5521.Meeting 最短路模板题

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  2. HDU 5521 Meeting(虚拟节点+最短路)

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) Total ...

  3. hdu 5521 Meeting(最短路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5521 题意:有1-n共n个点,给出m个块(完全图),并知道块内各点之间互相到达花费时间均为ti.已知两 ...

  4. HDU 5521 Meeting【最短路】

    今天旁观了Angry_Newbie的模拟区域赛(2015shenyang) 倒着看最先看的M题,很明显的最短路问题,在我看懂的时候他们已经开始敲B了. 后来听说D过了很多人.. D题一看是个博弈,给了 ...

  5. HDU 5521 [图论][最短路][建图灵感]

    /* 思前想后 还是决定坚持写博客吧... 题意: n个点,m个集合.每个集合里边的点是联通的且任意两点之间有一条dis[i]的边(每个集合一个dis[i]) 求同时从第1个点和第n个点出发的两个人相 ...

  6. HDU 5521 Meeting

    2015 ACM / ICPC 沈阳站现场赛 M题 最短路 设置N+M个节点,前N个节点是Block,后M个节点是Set,每一组Set中的点向该Set连边,从1和n开始分别求最短路.注意爆int. # ...

  7. HDU - 5521 Meeting (Dijkstra)

    思路: 看了好久才看懂题意,文中给了n个点,有m个集合,每个集合有s个点,集合内的每两个点之间有一个权值为t的边,现在有两个人,要从1号点,和n号点,走到同一个顶点,问最少花费以及花费最少的点. 那就 ...

  8. HDU 5521:Meeting(最短路)

    http://acm.hdu.edu.cn/showproblem.php?pid=5521 Meeting Problem Description   Bessie and her friend E ...

  9. hdu 5521 最短路

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

随机推荐

  1. 自己动手实现STL:前言

    一.前言 最近,刚看完<STL源码剖析>,深深被实现STL库的那些的大牛们所折服.同时又感觉自己与大牛们差距之大,便萌生深入学习之意.如果仅仅只是看看<STL源码剖析>的话,又 ...

  2. 在Windows下通过命令行或者.bat文件统计一个目录中文件数量

    在Windows下面怎样通过命令行统计一个目录中文件的数量,或者说,如果在一个.bat文件中,统计一个目录中的文件数量? 我原来以为是不可能的,要编一个vbs程序什么的,后来到网上找了下,发现还真是可 ...

  3. css虚线和css双实线

    border线型主要有:1.dotted[点状]2.solid[实线] 3.double[双实线] 4.dashed;[虚线] 如果一个CSS这样写:border-style:dotted solid ...

  4. 出现错误ActivityManager: Warning: Activity not started, its current task has been

    1.在学习两个Activity的切换时,重新把新的工程部署上模拟器时候出现错误:ActivityManager: Warning: Activity not started, its current ...

  5. [经验] - JQuery.Ajax + 跨域 (crossDomain) + POST + JSON + WCF RESTful, 5大陷阱和解决方案

    最近在开发WSS RESTful服务的时候, 碰到了这些个纠结的问题. 在网上查找了半天, 找到n多种解决方案, 但是都是部分的, 要么是没有跨域的情况, 要么是没有post的情况, 要么不是用WCF ...

  6. HelloX操作系统与中国移动OneNET物联网平台成功完成对接

    HelloX成功与中国移动物联网平台对接 经过HelloX项目组同仁的努力,尤其是Tywin(@飓风)的努力下,HelloX最新版本V1.78已成功与中国移动OneNET(open.iot.10086 ...

  7. dagli最早干了这样一件事儿 Localization of Cardiac-Induced Signal Change in fMRI

    Localization of Cardiac-Induced Signal Change in fMRI 这篇文章是最早做生理噪声相关组织的定位的. 很奇特,因为,这位学者甚至得出了,血管心动等变化 ...

  8. Linux 中直接 I/O 机制的介绍

    https://www.ibm.com/developerworks/cn/linux/l-cn-directio/ 对于传统的操作系统来说,普通的 I/O 操作一般会被内核缓存,这种 I/O 被称作 ...

  9. C# 总结

    转自原文 C# 总结 1.类型是隐式内部的.(类) 2.类型成员是隐式私有的.(方法) 3.常量定义:const 是隐式static的,必须在定义时设置初始值. 4.只读字段:readonly 可以在 ...

  10. 【剑指offer 面试题15】链表中倒数第K个结点

    思路: 定义两个指针同时指向head,第一个指针先走K-1步,随后二个指针同时移动,当第一个指针到末尾处时,第二个指针所指向的即为倒数第K个结点. #include <iostream> ...