【C++】树状数组
创始人
2024-06-02 12:23:46
0

定义:

所谓树状数组,逻辑结构是一棵树,但是采用数组实现,他能解决单点修改区间查询类的问题,属于前缀和的一种优化。

lowbit:

学习树状数组,首先要引入lowbit 概念,所谓 lowbit,指的是二进制数最低位的1的权值,比如二进制数1100的lowbit就是二进制表示就是100,也就是权值为2^2 = 4,下文中我们用lowbit(x)表示x 的lowbit值。实际上,lowbit(x)= x&(−x),&表示按位与运算。

int lowbit(int x) {return (x & (-x));
}
#define lowbit(x) (x & (-x))

在c语言中,一个数的负数的二进制为该数字取反后加一(-x)等于(~x + 1),其中~符号表示为取反,如某个数的二进制为(10100100),则取反后为(01011011),再加一为(0101100),注意原码,反码,补码的含义。

原码:001010
反码:110101
补码:110110反码加一后为改数学负数的二进制表达形式

如     x : 1001010110

      ~x :  0110101001

~x + 1 :  0110101010,

从最低位到最高位,如果x的二进制形式下这个位置是0,则取反之后变成1,1 + 1就会往前进位,知道x的某一位为1时,进位结束.因此 lowbit (x):x的二进制形式下最低位的1的权值.

树状数组结构

在图中Ai表示原数组,Ci 表示Ai对应的树状数组。

Ci 维护的是 Ai的区间信息,那么 Ci究竟维护什么区间呢?我们可以先计算下lowbit(i).

lowbit(1)=1
lowbit(2)=2
lowbit(3)=1
lowbit(4)=1
lowbit(5)=1
lowbit(6)=2
lowbit(7)=1
lowbit(8)=8

我们可以发现,Ci 维护的长度就是 lowbit(i),维护区间是 [i−lowbit(i)+1,i]。

如C3维护的区间是[2−lowbit(2)+1,2]即[1,2],C8维护的区间是[8−lowbit(8)+1,8]即[1,8]。

那么树状数组的 Ci 可能会影响哪些位的值呢?以C1为例,1+lowbit(1)=2,2+lowbit(2)=4,4+lowbit(4)=8,我们发现第 i 个数值会递归影响所有的父结点,在树状数组中编号为i 的结点的父结点编号为 i+lowbit(i)。

 

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...