[note]克鲁斯卡尔重构树

克鲁斯卡尔重构树

又叫并查集重构树
大概在NOI2018之前还是黑科技
现在?烂大街了
主要是针对图上的对边有限制的一类问题
比如每次询问一个点u不能经过边权大于w的边能走到的第k大点权是多少
也就是这个题peaks
首先肯定是一个最小生成树(如果不知道为什么还可以先做货车运输)
我们在并查集合并的时候稍作修改
每次不是fa[x]=y而是fa[x]=fa[y]=++tot
这样相当于新建了一个点连接两棵树,tot的点权根据题目需要确定
peaks这题点权就是所连边的边权
我们发现这样子构出来的树具有十分优美的性质
总点数2n-1
叶子全都是图上原来的点
从根到叶子点权具有单调性
于是可以树上倍增找到最浅的祖先(点权<=询问的w)
然后子树里的叶子都是可以走到的
之后再根据需要主席树或者别的什么搞一搞就行
例题的话:
peaks
NOI2018归程
IOI2018狼人

转载于:https://www.cnblogs.com/sdzwyq/p/10038730.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值