GDKOI2021普及组Day1D旅行
1447+
作者:crxis 发布:2021-02-02 分类:生成树
题目大意:n个点m条边,每条边有费用,请问从起点s开始,花费不超过w能到多少个点?(可以买票,买票后费用不超过票价的边都可以免费走)
解题思路
显然,有多少钱,就买多少票!因为超过w的边都走不了;买票后,不超过w的边都可以走!
对于一个询问,我们可以Flood Fill爆搜一遍;对于多个询问,每次都爆搜会超时,但如果能不重复搜索边即可高效解决问题。
我们可以按照边排序、询问的花费排序,每次询问,我们将不超过费用的边合并,用并查集统计集合大小,并依次回答即可。
(显然边不需要重复合并、最后按照询问的编号输出即可。)