系统警告,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. 简单易懂的Servlet路径问题

    关于servlet路径,我看了一下网上别人的博客园,发现都有一个通病,讲的太专业了,又抓不住关键部分,往往看一眼就不想看第二眼.所以我特地准备了初学者所通识的servlet路径问题. 1.标识符 /j ...

  2. webpack进阶(二)

    1)webpack动态打包所有依赖项,避免打包未使用的模块. 2)转换css的loader有:css-loader,style-loader,加载图片或文件的loader是:file-loader,如 ...

  3. 微信小程序之登录连接django,以及用户的信息授权认证

    小结: 1 如何自定义组件 - 组件和页面一样,也是由四个文件组成,所以我们自定义组件的时候,模拟pages文件夹,把所有的所有的组件都放在一个文件夹中,每个组件又由一个文件夹包裹,方便管理,在对应目 ...

  4. Tries前缀树

    Trie,来源于(retrieval,取回,数据检索),是一种多叉树,用来存储字母表上的单词非常有用. Trie经常用来存储动态集合(dynamic set)或者关联数组(associative ar ...

  5. vue2.0:项目开始,首页入门(main.js,App.vue,importfrom)

    对main.js App.vue 等进行操作: 但是这就出现了一个问题:什么是main.js,他主要干什么用的?App.vue又是干什么用的?main.js 里面的import from又在干嘛?ne ...

  6. 深度学习与人类语言处理-语音识别(part2)

    上节回顾深度学习与人类语言处理-语音识别(part1),这节课我们将学习如何将seq2seq模型用在语音识别 LAS 那我们来看看LAS的Encoder,Attend,Decoder分别是什么 Lis ...

  7. 小白的docker极简入门(二)、5分钟教你玩转docker安装

    0-前言 上一篇中,我们已经安装后Linux了,我们需要在Linux下安装docker,然后才能在docker中安装和部署各种应用 同样,5分钟教你完成docker正确安装和使用, 不是纸上谈兵,不是 ...

  8. Asp.net Repeater控件的绑定与操作

    由于repeater 控件具有的一个特性--循环 <ItemTemplate>的内容,Repeater 控件里的某个元素对象的绑定与获取,不像平常的,直接使用控件的 id 便可以给该控件进 ...

  9. 一段很简单的PHP代码,用于手机拨号

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  10. 解决Tomcat控制台输出乱码问题

    解决Tomcat控制台输出乱码问题 打开Edit Configuration,在VM options一栏输入 -Dfile.encoding=UTF-8 然后到IDEA的bin目录找到 idea64. ...