[最小生成树][最短路]最小代价

该博客探讨了一幅无向带权图的问题,其中黑点和白点需要通过最短路径连接,目标是最小化总代价。博主介绍了如何通过求解多点最短路,构建超级点并进行最短路计算,以及使用并查集优化最小生成树来找到最小代价。当黑点和白点不连通时,输出'Impossible',否则输出最小代价。
摘要由CSDN通过智能技术生成

题目描述

给出一幅由n个点m条边构成的无向带权图。
其中有些点是黑点,其他点是白点。
现在每个白点都要与他距离最近的黑点通过最短路连接(如果有很多个黑点,可以选取其中任意一个),我们想要使得花费的代价最小。请问这个最小代价是多少?
注意:最后选出的边保证每个白点到离它最近的黑点的距离仍然等于原图中的最短距离。

Input
第一行两个整数n,m;
第二行n 个整数,0表示白点,1 表示黑点;
接下来m 行,每行三个整数x,y,z,表示一条连接x和y 点,权值为z 的边。

Output
如果无解,输出impossible;
否则,输出最小代价。

Sample Input
5 7
0 1 0 1 0
1 2 11
1 3 1
1 5 17
2 3 1
3 5 18
4 5 3
2 4 5

Sample Output
5
【样例解释】
选 2、4、6三条边

Data Constraint
对30%的输入数据: 1≤n≤10, 1≤m≤20;
对100%的输入数据:1≤n≤100000,1≤m≤200000,1≤z≤1000000000

分析

我们容易求出所有点到最近黑点的值:只要反过来,对黑点求到其他点的最短路即可,但是= =
多点最短路你做过吗?
容易想到建超级点(有点像网络流是吧)连接所有黑点,边权0,单向边
那么对超级点跑最短路即可
【其中超级点延伸的最短路必定只经过一个黑点,因为经过大于一个肯定不优】
求出值以后,我们看一下:
如果有边 1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值