树上差分

转自:https://blog.csdn.net/a_forever_dream/article/details/83505521

对点的差分

d 是差分数组 a是节点 fa是父节点
d[x]+1相当于a[root]~a[x]+1

给树上一条链x~y的节点全部+1
当 x 是 y 的祖先时
d[y]+1,d[fa[x]]-1即可。d[y]+1是给y~root的节点全部+1,d[fa[x]]-1把fa[x] ~ root的节点全部-1。

任意情况下时
把x~ y拆成x~ lca(x,y)和y~ lca(x,y)。具体操作为d[x]+1,d[fa[lca]]-1,d[y]+1,d[fa[lca]]-1,d[lca]-1,d[fa[lca]]+1。

统计结果
对于一个节点的权值,统计其子树内的差分数组即可。

对边的差分

因为每一个节点与父亲之间的边是唯一的,所以,我们让每个节点就代表那一条边。即a[i]表示节点i与fa[i]的边。稍微修改下对点的差分即可。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值