树状数组的区间查询与修改(1)

一维树状数组:

   1.单点修改+区间查询

          这是树状数组数组中最简单的一部分,也成为模板,直接上代码:

int lowbit( int x ){
    return x & -x;
}
void update( int x  , int y ){
    for( int i = x ; i <= n ; i += lowbit( i ) )
        c[i] += y;
}
long long sum( int x ){
    long long sum1 = 0;
    for( int i = x ; i > 0 ; i -= lowbit(i) )
        sum1 += c[i];
    return sum1;
}
//最后输出sum(r)-sum(l-1)即可

  2.区间修改+单点查询

     单点查询就不说了,我们想怎样进行区间修改,这里运用到了差分的思想(我也不知道对不对)。

        我们定义一个数组c[i]表示这个序列a[i]与a[i-1]的差(没有绝对值),而c[1]自然等于a[1],所以就有:

              ∑d[i](i = 1~p) =a[p]

     也就可以通过修改d[i]来表示前缀和

     而区间修改是从 first 到 last 中每一个数加上x , 则a[first]与a[first-1]差多了x ,a[last]与a[last+1]差少了x,其余的都没有变

     所以我们只需要将d[first]与d[last+1]改变就可以啦。

     参考代码(如何修改):

long long lowbit( long long x ){
    return x & -x;
}
void update( long long x , long long y ){
    for( int i = x ; i <= n ; i += lowbit(i) ){
        c[i] += y;
        
    }
}
void update( int first , int last , int delta){
    update( first , delta );
    update( last - 1 , delta );
}

 

 

 

 

 

     

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值