#P5845. [IOI2011] crocodile

[IOI2011] crocodile

题目描述

考古学家 Benjamas 考察了神秘的鳄鱼地下宫殿之后需要设法逃离。这个地下宫殿包含 NN 个洞穴和 MM 条双向的通道。每条通道连接一对不同的洞穴,两个洞穴之间最多只有一条通道,在不同的通道上行走可能需要不同的时间。NN 个洞穴中有 KK 个洞穴是出口洞穴, Benjamas 可以从出口洞穴逃离。Benjamas 从 00 号洞穴出发,她希望尽快地到达一个出口洞穴。

鳄鱼门卫要阻止 Benjamas 逃离宫殿。它可以通过机关来堵住任意一个的通道(任意时刻,只能堵住一个通道)。即无论何时,鳄鱼门卫堵住一个新的通道,则之前堵住的通道就会被打开。

Benjamas 逃离过程可以描述如下:每次她试图离开一个洞穴时,鳄鱼门卫都会封闭一条连接该洞穴的通道。Benjamas 只能选择没有被封闭的通道走到下一个洞穴。Benjamas 一旦进入一条通道,在她到达该通道的另一端前,鳄鱼门卫不能封闭这条通道。当 Benjamas到达下一个洞穴,鳄鱼门卫可以选择再封闭一条通道(可以是 Benjamas 刚刚走过的那条通道)。

Benjamas 需要设计一个逃生计划,确切地说,她希望有一系列指令告诉她如何逃生。

AA 是一个洞穴,如果 AA 是出口洞穴,Benjamas 可以直接逃生。否则,对洞穴 AA,指令是下列形式中的一种:

  • 在洞穴 AA,优先选择一条通道到洞穴 BB。如果该通道被封堵,则选择另一通道去洞穴 CC

  • 不用考虑洞穴 AA,按照逃生计划不会到达 AA

注意:数据保证不管鳄鱼门卫如何封闭通道,总能找到一个好的逃生计划保证 Benjamas 在有限时间内可以到达一个出口洞穴。在所有逃生计划中,在最坏情况下用时最短的逃生计划所用的时间定义为 TT

输入格式

第一行三个整数 NNMMKK

接下来 MM 行 每行三个整数 表示一条无向边的两端和长度(无重边);

接下来 KK 个整数 表示出口洞穴。

输出格式

一个整数 最小时间 TT

13 12 9
0 1 1
0 2 4
0 3 11
1 4 11
1 5 7
1 6 15
2 7 3
2 8 13
2 9 23
3 10 3
3 11 1
3 12 2
4 5 6 7 8 9 10 11 12
13

提示

数据范围

对于 100%100\% 的数据,3N1053 \le N \le 10^52M1062 \le M \le 10^6,测试数据保证 TT 存在,且 T109T \le 10^9