系统警告,Bronya请求支援

Description

休伯利安号的一行人来到了由逆熵镇守的前文明遗迹[海渊城],他们准备用巨大的传送装置[海渊之眼]进入量子之海,寻找丢失的渴望宝石。然而在行动前夜爱因斯坦却遭到神秘人的袭击,下落不明,而海渊之眼也发生了原因不明的暴走。为了找回渴望宝石,布洛妮娅在一片混乱中,只身一人跳入了量子之海。布洛妮娅在经受认知回廊的考验之后,得到了逆熵盟主瓦尔特的帮助,并拿到了理之律者核心,然而就在这时,布洛妮娅接收到强烈的崩坏能警报,数据显示渴望宝石受到理之律者核心的激发变得极不稳定,会在x秒后爆发出强烈的崩坏能脉冲,布洛妮娅已经没有时间了,必须马上出发,“ 重装小兔19C,ride on!”。

量子之海由n个地点组成,编号1−n1 - n1−n,这些地点由mmm条双向道路连接,保证任意两个地点连通,在t=0t=0t=0时刻布洛妮娅在111号地点,渴望宝石在量子之海的最深处nnn号地点。布洛妮娅从一个地点沿着一条道路到达另一个地点需要111秒时间(当然布洛妮娅可以选择不移动),渴望宝石会在t=xt=xt=x时刻爆发,爆发只会持续一瞬间,但布洛妮娅无法承受如此强烈的崩坏能爆发,幸运的是在量子之海中有kkk个地点是安全的,能够躲避崩坏能的侵蚀,也就是说t=xt=xt=x时刻布洛妮娅必须待在其中一个安全地点里,等待爆发过后才能继续前往nnn号地点取回渴望宝石。(如果布洛妮娅能够在t≤xt \leq xt≤x时取回渴望宝石,就不会爆发)布洛妮娅必须尽快完成任务,但是她的生物芯片被烧毁了,无法计算出最少需要花费多少时间,因此她向舰长您请求帮助,请告诉布洛妮娅她最少需要花费多少时间才能取回渴望宝石。

Input

第一行三个整数n,m,xn,m,xn,m,x表示地点的数量,道路的数量,爆发的时间

接下来mmm行,每行两个整数a,ba,ba,b,表示aaa和bbb之间有一条双向道路连接。

接下来一行一个整数kkk,表示安全地点的数量

接着kkk行,每行一个整数kik_iki​,表示kik_iki​是安全地点

2≤n≤1e5, n−1≤m≤1e5,0≤x≤100,0≤k≤100,1≤ki ≤n2 \leq n \leq 1e5,  n-1 \leq m \leq1e5, 0 \leq x \leq 100,0 \leq k \leq 100,1 \leq k_i  \leq n2≤n≤1e5, n−1≤m≤1e5,0≤x≤100,0≤k≤100,1≤ki​ ≤n;

Output

如果布洛妮娅能够取回渴望宝石,输出最少需要花费多少时间,否则输出" -1 "。

//真的很想在output里面加中文,但好像判题机不允许   (´-ωก`)。

Sample Input 1

4 4 0
1 2
1 3
2 4
3 4
1
2

Sample Output 1

-1

Sample Input 2

4 4 1
1 2
1 3
2 4
3 4
1
2

Sample Output 2

2

Sample Input 3

4 4 5

1 2

1 3

2 4

3 4

1

2

Sample Output 3

2

Hint

对于第一个样例,布洛妮娅无法在爆发前到达安全地点,因此任务失败。

对于第二个样例,布洛妮娅在t=1t=1t=1时必须待在222号地点躲避崩坏能爆发。

对于第三个样例,布洛妮娅可以在x秒内取回渴望宝石,因此崩坏能不会爆发,答案是222s。

Source

休伯利安号退伍舰长Chter 指挥官编号:19470572

思路

分别以起点s、终点e 跑一遍最短路,首先看能否在规定时间内从s 到 e点,如果能到话直接输出时间,否则要现到躲避处,躲避t 秒,之后在从躲避点到达e点(这个路程所话多时间正用上了我们 终点e起点逆向跑最短路的这个过程)

代码

#include<iostream>
#include<queue>
#include<cstdio>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<string>
#include<vector>
#include<map>
#include<algorithm>
using namespace std; const int Len = 1e6;
const int INF = 1e9 + 10;
struct Edge
{
int v, w, next;
} edge[Len];
int head[2*Len];
int k = 0;
int n,m,t;
int pos[Len]; void Add(int u, int v, int w)
{
edge[++ k] = (Edge){ v, w, head[u]};
head[u] = k;
} void init()
{
k = 0;
} int dis1[Len], dis2[Len]; void Spfa(int s, int dis[])
{
int use[Len] = {0};
for(int i = 1; i <= n; i ++)
dis[i] = INF;
dis[s] = 0;
queue<int> q;
q.push(s);
int u,v;
while(! q.empty())
{
u = q.front(); q.pop();
use[u] = 0; for(int i = head[u]; i != 0; i = edge[i].next)
{
v = edge[i].v;
if(dis[v] > dis[u] + 1)
{
dis[v] = dis[u] + 1;
if(! use[v])
{
q.push(v);
use[v] = 1;
}
}
}
}
} int main()
{
// freopen("A.txt","r",stdin);
scanf("%d %d %d", &n, &m, &t);
int u,v;
for(int i = 1; i <= m; i ++)
{
scanf("%d %d", &u, &v);
Add(u,v,1);
Add(v,u,1);
}
int cnt;
scanf("%d", &cnt);
for(int i = 1; i <= cnt; i ++)
scanf("%d", &pos[i]); Spfa(1, dis1);
Spfa(n, dis2);
if(dis1[n] <= t)
{
printf("%d\n", dis1[n]);
}
else
{
int mn = INF;
for(int i = 1; i <= cnt; i ++)
if(dis1[pos[i]] <= t)
mn = min(mn, t + dis2[pos[i]]);
printf("%d\n", mn == INF ? -1 : mn);
} return 0;
}

系统警告,Bronya请求支援(两遍最短路)的更多相关文章

  1. UVA11374 Airport Express 正反两次最短路

    问题描述 洛谷(有翻译) 吐槽 一道坑题. 如何对待商务票 因为商务票只有一张,所以在\(k\)条边中只有一条边会被选中,很显然,最后这条边会被枚举. 如何选择使用商务票的边 假设我们正在枚举这条边, ...

  2. HDU5886 Tower Defence 【两遍树形dp】【最长链预处理】

    题意:N个点的一棵带权树.切掉某条边的价值为切后两树直径中的最大值.求各个边切掉后的价值和(共N-1项). 解法一: 强行两遍dp,思路繁琐,维护东西较多: dis表示以i为根的子树的直径,dis2表 ...

  3. srping mvc 集成CXF 导致类初始化两遍

    cxf依赖于spring的ContextLoaderListener,而spring mvc 则依赖于DispatcherServlet. 初始化DispatcherServlet的时候会依赖初始化一 ...

  4. AOP中Advice执行两遍的原因

    在我的spring项目中,Aop的Advice执行了两边,就好像拦截了两遍一样. 原因是:切面应该切到接口的实现类上,而不是接口上

  5. 在taro中跳转页面的时候执行两遍componentDidMount周期的原因和解决方法

    在做taro跳转的时候,发现在跳转后的页面会走两遍componentDidMount周期,查看了github上的issues,发现是跳转路由带参为中文引起的,只要把中文参数进行urlencode解决 ...

  6. Magic Potion(最大流,跑两遍网络流或者加一个中转点)

    Magic Potion http://codeforces.com/gym/101981/attachments/download/7891/20182019-acmicpc-asia-nanjin ...

  7. tomcat启动项目被重新加载,导致资源初始化两遍

    之前没有遇到过这个问题,配了三天的项目了,惊人啊!!!各种怪问题全被我赶上了.真有种骂人的冲动. tomcat启动项目时,项目资源被加载两遍. 原因:配置虚拟目录导致,项目被重新加载. <Hos ...

  8. Linux系统实现虚拟内存有两种方法:交换分区(swap分区)和交换文件

    Linux系统实现虚拟内存有两种方法:交换分区(swap分区)和交换文件 交换文件 查看内存:free -m , -m是显示单位为MB,-g单位GB 创建一个文件:touch /root/swapfi ...

  9. log4j2 日志打两遍的问题

    在使用log4j2的时候,一般都需要不同的日志分类打印不同的日志等级,如下面的配置 <!-- 用于指定log4j自动重新配置的监测间隔时间,单位是秒 --> <configurati ...

随机推荐

  1. 025.掌握Service-SVC基础使用

    一 Service简介 1.1 Service概念 Service是Kubernetes的核心概念,通过创建Service,可以为一组具有相同功能的容器应用提供一个统一的入口地址,并且将请求负载分发到 ...

  2. 一起了解 .Net Foundation 项目 No.18

    .Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. Protobuild Pr ...

  3. SpringBoot WebSocket STOMP 广播配置

    目录 1. 前言 2. STOMP协议 3. SpringBoot WebSocket集成 3.1 导入websocket包 3.2 配置WebSocket 3.3 对外暴露接口 4. 前端对接测试 ...

  4. C++ 标准模板库(STL)-stack

    主要介绍一下C++11版本中标准模板库中栈的用法,希望可以帮到需要用的人. #include <iostream> #include <stack> #include < ...

  5. vux中表单验证,在提交时自动聚焦到未验证通过的那栏;及循环表单的验证

    首先vux中的表单验证在点击触发,失焦时才显示错误信息,如果不管它,它就没反应,这显然是不合理的:解决办法就是:在提交时做验证,不通过的话就使用.focus()及.blur()方法给它聚焦,失焦. i ...

  6. 【Weiss】【第03章】练习3.13:桶排序

    [练习3.13] 利用社会安全号码对学生记录构成的数组排序.编写一个程序进行这件工作,使用具有1000个桶的基数排序并且分三趟进行. Answer: 首先,对社会安全号码不了解的就把它当成一个不超过9 ...

  7. 使用SpringBoot + JavaMailSender 发送邮件报错 Mail server connection failed;Could not connect to SMTP host

    说明: 出于安全考虑,阿里云默认封禁 TCP 25 端口出方向的访问流量,无法在阿里云上的云服务器通过 TCP 25 端口连接外部地址. [官方提示]:如果您需要使用阿里云上的云服务器对外部发送邮件, ...

  8. Symantec NBU :Unable to retrieve version of the server xxx.xxx.xxx

    Symantec NetBackup  是赛门铁克收购的veritas公司的一款产品,该产品功能强大,据称堪称备份界的鼻祖. 其具体原理和备份方式可见:https://blog.51cto.com/s ...

  9. Linux Cgroup 入门教程:cpuset

    这是 Cgroup 系列的第四篇,往期回顾: Linux Cgroup 入门教程:基本概念 Linux Cgroup 入门教程:CPU Linux Cgroup 入门教程:内存 通过上篇文章的学习,我 ...

  10. CSS三角形/气泡的实现原理及应用

    记得第一次面试,面试官问如何用css实现一个不规则三角形?好叭 ·-·,触及到知识盲区了,手动叹气(╥﹏╥),好在别的回答的还好,没挂