树状数组


树状数组

手画的图有点丑emmm

这里写图片描述
第一个函数
lowbit函数(找出这个数对应的二进制从右往左数第一个为1的数字)
求lowbit有两种方法

 1.   int lowbit (int x)

    {

       return x&-x;       //利用的是补码

    }
  2.
  int lowbit(int i)
{
    int ans=i-(i&(i-1));    //利用的是二进制
    return ans;
}

第二个函数
更新函数

//更新单点
void add(int i,int c)
{
    while(i<=n)
    {
        a[i]+=c;
        i+=lowbit(i);
    }
}
//举个栗子,如果想更新a[3],那么就要更新c4和c8,因为c4和c8都与a3有关,
//由上图可以看出

第三个函数
求和函数

int query(int i)
{
    int sum=0;
    while(i>0)
    {
        sum+=a[i];
        i-=lowbit(i);
    }
    return sum;
}
//比如6的lowb为2,所以前六项的和应该是c6+c(6-2)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值