news 2026/5/13 19:56:04

20260112树状数组总结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
20260112树状数组总结

引子

树状数组是一种支持单点修改和区间查询码量低常数小的数据结构。

任何数字都可以表示为不超过logn个2的幂次之和,例如7=4+2+1,这一特性就是树状数组的核心理论。

关键在于设计一种数据结构,使得任意前缀和都能由logn个区间和表示以及每个位置最多被logn个区间覆盖,这样就能实现单点修改和区间查询。

树状数组通过lowbit运算实现这一目标。lowbit定义为数字二进制表示中最右边的1所代表的值,可通过x&-x快速计算。例如6的lowbit是2(110)、8的lowbit是8(1000)

在具体实现中,t[i]存储以 i 为右端点长度为lowbit(i)的区间和,前缀和计算采用递推的方式sum(7)=t[7]+t[6]+t[4],其中6=7-lowbit(7)4=6-lowbit(6)

单点更新时,由于t[i]包含位置 i,所以只需要沿着lowbit递增的方向更新所有相关区间就行了,同样利用lowbit实现高效处理。

B3612 【深进1.例1】求区间和

虽然这道题用前缀和比树状数组快一倍,但如果用树状数组写的话呃比模板题会简单一些。

#include<bits/stdc++.h>usingnamespacestd;//树状数组参考模板ints[100005],n;intlowbit(intx){//lowbit函数returnx&(-x);}voidadd(inti,intx){//递增for(;i<=n;i+=lowbit(i))s[i]+=x;}intsum(inti){//求区间和intsm=0;for(;i>0;i-=lowbit(i))sm+=s[i];returnsm;}intmain(){cin>>n;for(inti=1;i<=n;i++){intx;cin>>x;add(i,x);//递增}intm;cin>>m;while(m--){intl,r;cin>>l>>r;cout<<sum(r)-sum(l-1)<<endl;//前缀和}return0;}

P3374 【模板】树状数组 1

单点修改和区间查询。

这里说明一下树状数组是可以中途单点修改的。

#include<bits/stdc++.h>usingnamespacestd;ints[500005],n;intlowbit(intx){returnx&(-x);}voidadd(inti,intx){for(;i<=n;i+=lowbit(i))s[i]+=x;}intsum(inti){intsm=0;for(;i>0;i-=lowbit(i))sm+=s[i];returnsm;}intmain(){intm;cin>>n>>m;for(inti=1;i<=n;i++){intx;cin>>x;add(i,x);}while(m--){intopt,x,y;cin>>opt>>x>>y;if(opt==1){//这里判断一下是单点修改还是区间查询add(x,y);}else{cout<<sum(y)-sum(x-1)<<endl;//还是前缀和}}return0;}

P3368 【模板】树状数组 2

区间修改和单点查询。

首先直接x到y都递增一次会发现TLE70分,于是考虑用树状数组维护一个差分数组,三函数一样,输入a数组时add(a[i]-a[i-1]);要区间修改时add(l,k)add(r+1,k),还是差分;单点查询时输出sum(x),相当于差分之后进行一次前缀和。

#include<bits/stdc++.h>usingnamespacestd;inta[500005],s[500005],n;intlowbit(intx){returnx&(-x);}voidadd(inti,intx){for(;i<=n;i+=lowbit(i))s[i]+=x;}intsum(inti){intsm=0;for(;i>0;i-=lowbit(i))sm+=s[i];returnsm;}intmain(){intm;cin>>n>>m;for(inti=1;i<=n;i++){cin>>a[i];add(i,a[i]-a[i-1]);}while(m--){intopt;cin>>opt;if(opt==1){intx,y,k;cin>>x>>y>>k;add(x,k);add(y+1,-k);}else{intx;cin>>x;cout<<sum(x)<<endl;}}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 8:36:03

性能对比:Image-to-Video不同参数设置效果测评

性能对比&#xff1a;Image-to-Video不同参数设置效果测评 1. 引言 随着多模态生成技术的快速发展&#xff0c;图像转视频&#xff08;Image-to-Video, I2V&#xff09;已成为内容创作、影视预演和交互设计中的关键工具。基于 I2VGen-XL 模型构建的 Image-to-Video 图像转视频…

作者头像 李华
网站建设 2026/5/9 6:33:34

2025智能驾驶革命:手把手教你用openpilot让普通汽车秒变智能座驾

2025智能驾驶革命&#xff1a;手把手教你用openpilot让普通汽车秒变智能座驾 【免费下载链接】openpilot openpilot 是一个开源的驾驶辅助系统。openpilot 为 250 多种支持的汽车品牌和型号执行自动车道居中和自适应巡航控制功能。 项目地址: https://gitcode.com/GitHub_Tre…

作者头像 李华
网站建设 2026/5/13 18:41:07

QGroundControl地面站完整安装手册:从新手到专家的简单指南

QGroundControl地面站完整安装手册&#xff1a;从新手到专家的简单指南 【免费下载链接】qgroundcontrol Cross-platform ground control station for drones (Android, iOS, Mac OS, Linux, Windows) 项目地址: https://gitcode.com/gh_mirrors/qg/qgroundcontrol 你是…

作者头像 李华
网站建设 2026/5/9 11:11:20

YimMenu终极安全辅助工具:从零到精通的完整实战指南

YimMenu终极安全辅助工具&#xff1a;从零到精通的完整实战指南 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/YimMen…

作者头像 李华
网站建设 2026/5/9 5:31:41

YimMenu终极配置手册:快速掌握GTA V辅助工具完整使用技巧

YimMenu终极配置手册&#xff1a;快速掌握GTA V辅助工具完整使用技巧 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/Y…

作者头像 李华
网站建设 2026/5/9 19:43:42

纯净音乐革命:为什么这款免费听歌应用正在改变你的音乐体验?

纯净音乐革命&#xff1a;为什么这款免费听歌应用正在改变你的音乐体验&#xff1f; 【免费下载链接】tonzhon-music 铜钟 (Tonzhon.com): 免费听歌; 没有直播, 社交, 广告, 干扰; 简洁纯粹, 资源丰富, 体验独特&#xff01;(密码重置功能已回归) 项目地址: https://gitcode.…

作者头像 李华