树状数组复习

基本原理

树状数组的原理简单来说就是利用二进制拆分区间
我们可以对一个数进行二进制分解,最多分解成log(x)个数,同样我们可以对[1,n]这个区间进行分解。也是最多log段,每次修改时我们维护受到影响的区间,然后查询时用这log个区间拼凑出一个前缀。这就是树状数组的大概思想。
最基本的作用是动态维护前缀和
在定义树状数组时,我们定义c[i]
c[x]=i=xlowbit(x)+1xa[i]c[i][xlowbit(x)+1,x]
image
image

重点:
c[x]
image

操作

1.查询

x-=lowbit(x)就是下次个要跳到的地方

int ask(int x)
{
	int sum=0;
	auto lowbit=[](x){return x&-x;};
	for(;x;x-=lowbit(x))	sum+=c[x];
	return sum;	
}

2.修改
树状数组修改时要将,从当前点到根节点这以路径上的所有点都进行修改

void add(int x,int y)
{
	for(x;x<=n;x+=lowbit(x)) c[x]+=y;
}

建树过程就看成n次修改过程时间复杂度为O(nlogn)

posted @   cxy8  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
点击右上角即可分享
微信分享提示