[COGS2632] [HZOI 2016] 数列操作d

这篇博客介绍了一道关于数列操作的题目,支持两种区间操作:1) 给指定区间内的数加上权值;2) 查询区间内的权值和。作者提到可以使用线段树或树状数组来解决,重点讲解了使用树状数组的方法,通过分解操作为二次项、一次项和常数项进行单点插入,并在不同情况下更新这些项,从而高效地计算区间和。
摘要由CSDN通过智能技术生成

题目

一个长度为 n 的序列,一开始序列数的权值都是 0 ,有 m 次操作
支持两种操作,
1 L R x ,给区间 [L,R] 内位置为 pos 的数加上 (posL)x
0 L R ,查询区间 [L,R] 内的权值和
最终答案对 1e9+7 取模

题解

这是我偶然翻到学弟学妹们出的一道题,于是就做了做。
首先这道题肯定能用线段树做,随便打打标记。
但是这道题也可以用树状数组做,更快,但是思想应该比线段树复杂些,就当是锻炼一下了。
下面是树状数组做法。

便于理解,将题目中的 x k 表示。
树状数组求区间 [L,R] 权值和的一般做法就是 Sum(R)Sum(L1) 。于是,首要任务就是找到正确的单点插入方法,使得可以利用树状数组求出 Sum(x)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值