题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5521

题目大意:

有 \(n\) 个点 \(m\) 个集合,一个点可能处于若干个集合内,属于第 \(i\) 个集合的任意两点间的距离是 \(t_i\) ,点 \(1\) 是起点,点 \(n\) 是终点。

你现在需要找到所有点中到 \(1\) 、 \(n\) 两点的距离的较大值的最小值,并输出所有满足要求的点。

解题思路:

这道题目难的不是最短路,而是建图。

因为最多可能有 \(n\) 个点在同一个集合,而 \(n \le 2 \times 10^5\) ,所以两两之间建边显然是不可取的,所以我们需要采用另一种方式建图:

为每一个集合对应一个点,第 \(i\) 个集合对应点 \(n+i\) ,然后从 \(n+i\) 连向所有第 \(i\) 个集合中的点一条权值为 \(t_i\) 的有向边,从第 \(i\) 个集合中的所有点连向点 \(n+i\) 一条权值为 \(0\) 的边。然后分别以点 \(1\) 和点 \(n\) 为起点求两边最短路。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 200020;
int T, n, m, e, dist1[maxn], dist2[maxn];
bool inq[maxn];
struct Node {
int v, w;
Node () {};
Node (int _v, int _w) { v = _v; w = _w; }
};
vector<Node> g[maxn];
queue<int> que;
vector<int> ans_vec;
// 一共n+m个点
void init() {
for (int i = 1; i <= n+m; i ++) g[i].clear();
}
void spfa(int st, int dist[]) {
memset(dist, -1, sizeof(int)*(1+n+m));
memset(inq, 0, sizeof(inq));
while (!que.empty()) que.pop();
dist[st] = 0;
que.push(st);
while (!que.empty()) {
int u = que.front();
que.pop();
inq[u] = false;
int sz = g[u].size();
for (int i = 0; i < sz; i ++) {
int v = g[u][i].v, w = g[u][i].w;
if (dist[v] == -1 || dist[v] > dist[u] + w) {
dist[v] = dist[u] + w;
if (!inq[v]) {
inq[v] = true;
que.push(v);
}
}
}
}
}
int main() {
scanf("%d", &T);
for (int cas = 1; cas <= T; cas ++) {
scanf("%d%d", &n, &m);
init();
for (int i = 1; i <= m; i ++) {
int t, s, u;
scanf("%d%d", &t, &s);
while (s --) {
scanf("%d", &u);
g[n+i].push_back(Node(u, t));
g[u].push_back(Node(n+i, 0));
}
}
spfa(1, dist1);
spfa(n, dist2);
int ans = -1;
for (int i = 1; i <= n; i ++)
if (dist1[i] != -1 && dist2[i] != -1 && (ans==-1 || ans > max(dist1[i], dist2[i])))
ans = max(dist1[i], dist2[i]);
printf("Case #%d: ", cas);
if (ans == -1) puts("Evil John");
else {
printf("%d\n", ans);
ans_vec.clear();
for (int i = 1; i <= n; i ++) if (dist1[i] != -1 && dist2[i] != -1 && max(dist1[i], dist2[i])==ans)
ans_vec.push_back(i);
int sz = ans_vec.size();
for (int i = 0; i < sz; i ++) {
if (i) putchar(' ');
printf("%d", ans_vec[i]);
}
puts("");
}
}
return 0;
}

HDU5521 Meeting 题解 最短路的更多相关文章

  1. HDU5521 Meeting(dijkstra+巧妙建图)

    HDU5521 Meeting 题意: 给你n个点,它们组成了m个团,第i个团内有si个点,且每个团内的点互相之间距离为ti,问如果同时从点1和点n出发,最短耗时多少相遇 很明显题目给出的是个无负环的 ...

  2. [JZOJ5279]香港记者题解--最短路图

    [JZOJ5279]香港记者题解--最短路图 题目链接 过 于 暴 力 分析 有一个naiive的想法就是从1到n跑最短路,中途建图,然后在图上按字典序最小走一遍,然而·这是不行的,你这样跳不一定能跳 ...

  3. hdu-5521 Meeting(最短路)

    题目链接: Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) ...

  4. hdu5521(Meeting)spfa 层次网络最短路

    题意:给出几个集合,每个集合中有Si个点 且任意两个点的距离为ti,现在要求两个人分别从1和n出发,问最短多长时间才能遇到,且给出这些可能的相遇点; 取两个人到达某点时所用时间大的值 然后取最小的   ...

  5. [hdu5521 Meeting]最短路

    题意:有N个点,给定M个集合,集合Si里面的点两两之间的距离都为Ti,集合里面的所有点数之和<=1e6.有两个人分别在1和N处,求1个点使得两个人到这一点距离的最大值最小 思路:这题是裸的最短路 ...

  6. URAL 1085 Meeting(最短路)

    Meeting Time limit: 2.0 secondMemory limit: 64 MB K friends has decided to meet in order to celebrat ...

  7. hdu 5521 Meeting(最短路)

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

  8. hdu5521 Meeting

    传送门 题目 Bessie and her friend Elsie decide to have a meeting. However, after Farmer John decorated hi ...

  9. HDU 5521:Meeting(最短路)

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

随机推荐

  1. iptables 防止DoS攻击

    SYN洪水是攻击者发送海量的SYN请求到目标服务器上的一种DoS攻击方法,下面的脚本用于预防轻量级的DoS攻击:ipt-tcp.sh: iptables -N syn-flood (如果您的防火墙默认 ...

  2. 如何把thinkphp 的url改为.html

    ThinkPHP支持伪静态URL设置,可以通过设置URL_HTML_SUFFIX参数随意在URL的最后增加你想要的静态后缀,而不会影响当前操作的正常执行.例如,我们设置'URL_HTML_SUFFIX ...

  3. poj 3862 && LA 4589 Asteroids (三维凸包+多面体重心)

    3862 -- Asteroids ACM-ICPC Live Archive 用给出的点求出凸包的重心,并求出重心到多边形表面的最近距离. 代码如下: #include <cstdio> ...

  4. jq实现超级简单的隔行变色

    文章地址:https://www.cnblogs.com/sandraryan/ <!DOCTYPE html> <html lang="en"> < ...

  5. [转]Java多线程学习(总结很详细!!!)

    Java多线程学习(总结很详细!!!) 此文只能说是java多线程的一个入门,其实Java里头线程完全可以写一本书了,但是如果最基本的你都学掌握好,又怎么能更上一个台阶呢? 本文主要讲java中多线程 ...

  6. [转]Android Studio实现代码混淆

     1,在build.grandle添加,其中规则写在proguard-rules.pro中,也可以自定义一个文件,将其代替,比如eclipse常用的 proguard-project.txt: bui ...

  7. 关于top命令

    top命令交互操作指令 下面列出一些常用的 top命令操作指令 q:退出top命令 :立即刷新 s:设置刷新时间间隔 c:显示命令完全模式 t::显示或隐藏进程和CPU状态信息 m:显示或隐藏内存状态 ...

  8. 【u236】火炬

    Time Limit: 1 second Memory Limit: 128 MB 2008北京奥运会,你想成为四川汶川的一名火炬手,结果层层选拔,终于到了最后一关,这一关是一道很难的题:任意给定一个 ...

  9. P1070 东风谷早苗

    题目描述 在幻想乡,东风谷早苗是以高达控闻名的高中生宅巫女.某一天,早苗终于入手了最新款的钢达姆模型.作为最新的钢达姆,当然有了与以往不同的功能了,那就是它能够自动行走,厉害吧(好吧,我自重).早苗的 ...

  10. activiti工作流引擎学习(二)

    1.连线 如果bpmn文件和java文件放在同一目录下,需要配置buildPath: 使用流程变量,设置连线需要的流程变量的名称,并设置流程变量的值,流程会按照指定的连线完成任务. 1.1一个活动中可 ...