橘猫发现了一个地图,这个地图上面居然有 maimai 的分布图!塑料一听就忍不住了,于是他把地图要了过来研究。
这张地图由 个点和
条带权无向边组成,现在我们定义
为点
到点
的最短距离。
塑料只关心其中的 个点
,于是他把这
个点提取出来并记录下它们之间的距离,而这
个点组成了一个新的无向图,边
的权值为原图中的
。
就当塑料还在规划路线的时候,橘猫突然对这个新的无向图的最小生成树的所有边的权值之和很感兴趣,于是他把这个问题留给了塑料,但显然笨笨的塑料并不擅长解决这种问题,于是这个问题就交给你啦!
本题有多组测试数据。
第一行输入一个数字
(
),表示有
组数据;
接下来对于每组数据,第一行输入三个整数
(
,
,
),表示点的数量和边的数量;
接下来
行,每行三个数字
(
,
),表示点
到点
有一条长度为
的路径。
接下来一行
个数字
,表示塑料关心的这
个点。
保证所有测试样例的
之和均不超过
。
保证给出的图是连通的。
对于每组测试样例,输出一个数字
,表示这个最小生成树的边的权值之和。
第一组测试样例的原图和新图如下:
原图 | 新图 |
可以发现:
其中,塑料只关心 这三个点,可以发现最后的生成树只包含
这两条边,故生成树的权值为
。
对于第二组测试样例:请注意可能有重边和自环。