[树状数组] 区间求和的三种模型

树状数组在区间求和问题上有很高的效率,尤其在非常困难的比赛中(数据量大,对时间限制很严格的比赛)能发挥非常大的作用,其各种复杂度都要比线段树低很多,而且其代码简洁优美……(好了我吹不下去了,赶紧开始)有关区间求和,主要有以下三个模型:
(以下设a[1…n]为一个长为n的序列,初始值全为0)

1、改点求段型:即对于序列A有以下操作:

  • 求整段区间的和:给定i,计算a1+a2+…+ai
  • 修改单点:给定x和c,执行ax += c

这是最容易的模型,使用bit[]树状数组就可以得到该答案:树状数组中不断进行前驱赋值就可以得到整个区间的和,对每个树状数组进行后继赋值就可以修改单点,复杂度都为log(n)。

//改点求段型
//原数组为a[1...n],树状数组为bit[1...n]
//操作【1】:ADD(x, c);  对a[x]加上c
//操作【2】:SUM(r)-SUM(l-1)。 计算sum(l,r)
int sum(int i)
{
    int 
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值