[BalticOI 2016 Day2] 城市

题目描述

在 Byteland 有 $n$ 个城市,并且其中有 $k$ 个国王经常来访的主要城市。 其中有 $m$ 条道路,每条道路连接两个城市。然而不幸的是,这些道路的环境极差使得国王无法全速驶过。 对于每条道路,翻修的成本是已知的。你的任务是选择性的翻修道路使得 $k$ 个主要城市都可以经过翻修后的道路互相连通,且总成本尽量小。

输入输出格式

输入格式


第一行,三个整数 $n,k$ 和 $m$,分别表示城市的个数,主要城市的个数和道路的个数。城市的编号分别为 $1,2,\dots,n$。 第二行,$k$ 个整数,表示主要城市。 接下来 $m$ 行,每行三个整数 $a,b$ 和 $c$,表示有一条双向道路从城市 $a$ 连接到城市 $b$,且翻修成本为 $c$。

输出格式


输出一行,表示满足以上条件的最小的总成本。

输入输出样例

输入样例 #1

4 3 6
1 3 4
1 2 4
1 3 9
1 4 6
2 3 2
2 4 5
3 4 8

输出样例 #1

11

说明

对于所有子任务,$1 \leq c \leq 10^9$ 且 $n \geq k$。 |子任务|分数|数据范围| |:-:|:-:|-| |1|22|$2 \leq k \leq 5,n \leq 20,1 \leq m \leq 40$| |2|14|$2 \leq k \leq 3,n \leq 10^5,1 \leq m \leq 2 \cdot 10^5$| |3|15|$2 \leq k \leq 4,n \leq 1000,1 \leq m \leq 2000$| |4|23|$k = 4,n \leq 10^5,1 \leq m \leq 2 \cdot 10^5$| |5|26|$k = 5,n \leq 10^5,1 \leq m \leq 2 \cdot 10^5$|