Fenwick Tree

Fenwick Tree,又称树状数组,是一种二叉索引树,用于快速区间信息的维护和查询。它提供O(nlog n)的预处理和O(log n)的更新与查询操作。通过低bit技巧,可以实现add(x,d)更新和query(l,r)查询功能,解决了传统前缀和在更新后的效率问题。初始化时,可以通过add(i,A[i])完成,具有较高的时间复杂度效率。" 122744412,12120508,西门子SinuTrain最新版仿真软件操作与调试,"['西门子', '数控系统', 'FPGA开发', '软件仿真', 'CSS']
摘要由CSDN通过智能技术生成

Fenwick树,俗称树状数组

也就是二叉索引树(Binary Indexed Tree,BIT)

它的作用是什么呢

支持快速区间信息的维护和查询

为什么说是快速,因为它真的很快
O(nlog n)预处理
O(log n)维护和更新

先来看一个问题

给定一个n个元素的数组A
我们进行下面两个操作
1 add(x,d): 让A[x]增加d
2 query(l,r): 计算A[l]+A[l+1]+…+A[r]

怎么办

计算前缀和S,这可以在O(1)的时间解决query。但一旦进行add之后前缀后要重新算过。
不难发现如果进行add(x,d),对前面的前缀和是没有影响的,所以只要更新x之后的就好了
但其实还是不行,以为每次更新的花费还是很大
为什么花费会大
因为一个S的信息存储太大了,所以我们改小一点
但也不能太小,否则和直接算就一样了
所以我们用一个新的东西来存

下面来看一个图

注意到这里的C和我们之前的S很像
那我们就这样处理
用C来记一个和,但不是前缀和,而是类似与前缀和

仔细看这个图,如果我们要求前缀和,从C一直向右走,

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值