数据结构:树状数组

什么是树状数组?

是用一种类似于二叉树的森林结构来模拟树形结构,顾名思义就是用数组模拟树形结构。

这是一个可以让算法的时间复杂度下降至与n转化成二进制数中的“1”的有关。

为什么不直接建树?

当然是因为它具有简便性,能用树状数组就不建树

树状数组的用途是?

它的基本用途是维护序列的前缀和。

简单来说就是可以用于求区间和,查询数,更新数等。

树状数组的结构?

这里介绍一种lowbit运算,lowbit(n)定义为非负整数n在二进制表示下“最低位的1及其后面所有的0”构成的数值。

通俗地讲,lowbit就是求数n的二进制中从低位开始,拢共有多少个连续0。

给定x,按二进制表示为:

x= 2^k +2^(k-1)+2^(k-2)+……+2^1+1;

那么x就能划分成以下区间:

(x-1 , x]

(x - 1 - 2^1, x-1 ]

(x - 1 - 2^1 - 2^2 , x - 1 - 2^1 ]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值