news 2026/4/27 16:01:13

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/4/22 2:17:53

Qwen1.5-0.5B-Chat保姆级教程:从零开始搭建Web对话界面

Qwen1.5-0.5B-Chat保姆级教程&#xff1a;从零开始搭建Web对话界面 1. 引言 1.1 学习目标 本文旨在为开发者提供一份完整、可操作的实践指南&#xff0c;帮助你基于 ModelScope 生态从零开始部署 Qwen1.5-0.5B-Chat 模型&#xff0c;并构建一个具备流式响应能力的 Web 对话界…

作者头像 李华
网站建设 2026/4/22 3:44:45

jQuery树形插件zTree_v3:5分钟从零构建层级结构界面

jQuery树形插件zTree_v3&#xff1a;5分钟从零构建层级结构界面 【免费下载链接】zTree_v3 jQuery Tree Plugin 项目地址: https://gitcode.com/gh_mirrors/zt/zTree_v3 zTree_v3是一款基于jQuery的高性能树形结构插件&#xff0c;专门为Web开发者提供快速构建文件管理、…

作者头像 李华
网站建设 2026/4/26 9:22:44

Open Interpreter人力资源:简历筛选脚本生成教程

Open Interpreter人力资源&#xff1a;简历筛选脚本生成教程 1. 引言 1.1 业务场景描述 在现代企业的人力资源管理中&#xff0c;招聘环节往往面临海量简历的处理压力。尤其是在校园招聘或大规模社招期间&#xff0c;HR团队需要从成百上千份简历中筛选出符合岗位要求的候选人…

作者头像 李华
网站建设 2026/4/25 12:58:01

AutoGLM-Phone-9B核心优势解析|附同款模型安装与验证教程

AutoGLM-Phone-9B核心优势解析&#xff5c;附同款模型安装与验证教程 1. AutoGLM-Phone-9B技术背景与核心价值 1.1 移动端大模型的演进挑战 随着多模态人工智能应用在移动端的快速普及&#xff0c;传统大语言模型因参数量庞大、计算资源消耗高&#xff0c;难以满足终端设备对…

作者头像 李华
网站建设 2026/4/22 3:46:35

Mochi Diffusion:Mac本地AI绘画的完整入门指南 [特殊字符]

Mochi Diffusion&#xff1a;Mac本地AI绘画的完整入门指南 &#x1f3af; 【免费下载链接】MochiDiffusion Run Stable Diffusion on Mac natively 项目地址: https://gitcode.com/gh_mirrors/mo/MochiDiffusion 想要在Mac上零门槛体验AI绘画的魅力吗&#xff1f;Mochi …

作者头像 李华
网站建设 2026/4/22 3:45:46

智能足球分析系统:从零构建AI驱动的完整解决方案

智能足球分析系统&#xff1a;从零构建AI驱动的完整解决方案 【免费下载链接】sports computer vision and sports 项目地址: https://gitcode.com/gh_mirrors/sp/sports 在现代足球领域&#xff0c;数据分析正经历着革命性的变革。传统的人工统计方法已经无法满足职业俱…

作者头像 李华