全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C++怎么实现一个树状数组_C++高效实现单点修改与区间求和的Fenwick树

树状数组通过lowbit实现高效单点更新和区间求和,支持O(log n)操作,适用于动态前缀和场景。

树状数组(Fenwick Tree)是一种高效处理单点更新区间求和的数据结构,代码简洁、常数小,特别适合在频繁修改与查询的场景中使用。C++ 实现 Fenwick 树非常直观,下面介绍其核心原理与实现方式。

树状数组的基本思想

Fenwick 树利用二进制特性维护前缀和。每个节点存储一段区间的和,通过 lowbit 操作快速定位父节点或子节点。支持:

  • 单点修改:更新某个位置的值,影响 O(log n) 个节点
  • 前缀查询:求 [1, i] 的和,访问 O(log n) 个节点
  • 结合前缀和可得任意区间 [l, r] 的和

lowbit 函数的实现

lowbit(x) 返回 x 的二进制表示中最低位 1 所对应的值,例如 lowbit(6)=2(6=110₂)。C++ 中可通过位运算高效实现:

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

树状数组的封装实现

以下是一个完整的 C++ 类封装,支持单点加法和区间求和:

#include 

class FenwickTree { private: std::vector tree; int n;

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

public: // 构造函数,n 为原数组长度 FenwickTree(int size) { n = size; tree.assign(n + 1, 0); }

// 单点增加:在位置 i 上加上 delta(i 从 1 开始)
void update(int i, int delta) {
    while (i zuojiankuohaophpcn= n) {
        tree[i] += delta;
        i += lowbit(i);
    }
}

// 前缀求和:[1, i] 的和
long long prefixSum(int i) {
    long long sum = 0;
    while (i youjiankuohaophpcn 0) {
        sum += tree[i];
        i -= lowbit(i);
    }
    return sum;
}

// 区间求和:[l, r] 的和(l 和 r 都从 1 开始)
long long rangeSum(int l, int r) {
    return prefixSum(r) - prefixSum(l - 1);
}

};

使用示例与注意事项

假设有一个初始数组 [1, 3, 5, 7, 9],我们可以这样使用 FenwickTree:

#include 
using namespace std;

int main() { FenwickTree fw(5);

// 模拟初始化:逐个添加元素
fw.update(1, 1);
fw.update(2, 3);
fw.update(3, 5);
fw.update(4, 7);
fw.update(5, 9);

cout zuojiankuohaophpcnzuojiankuohaophpcn "Sum [1,3]: " zuojiankuohaophpcnzuojiankuohaophpcn fw.rangeSum(1, 3) zuojiankuohaophpcnzuojiankuohaophpcn endl; // 输出 9
fw.update(2, 2); // A[2] += 2
cout zuojiankuohaophpcnzuojiankuohaophpcn "Sum [1,3] after update: " zuojiankuohaophpcnzuojiankuohaophpcn fw.rangeSum(1, 3) zuojiankuohaophpcnzuojiankuohaophpcn endl; // 输出 11

return 0;

}

注意:FenwickTree 通常基于 1 索引设计,传入的下标应从 1 开始。若原始数据是 0 索引,使用时需 +1 映射。

基本上就这些。实现简单,效率高,适合竞赛和工程中需要动态前缀和的场合。


# ai  # c++  # ios  # stream  # 封装  # 构造函数  # int  # 数据结构  # public  # 单点  # 树状  # 新和  # 是一个  # 是一种  # 适用于  # 我们可以  # 可通过  # 可得 


相关文章: 如何用PHP快速搭建CMS系统?  如何快速登录WAP自助建站平台?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  Swift中swift中的switch 语句  如何配置FTP站点权限与安全设置?  html制作网站的步骤有哪些,iapp如何添加网页?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  建站之星如何快速更换网站模板?  制作企业网站建设方案,怎样建设一个公司网站?  招贴海报怎么做,什么是海报招贴?  制作证书网站有哪些,全国城建培训中心证书查询官网?  如何在阿里云虚拟主机上快速搭建个人网站?  建站之星如何助力企业快速打造五合一网站?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  如何用低价快速搭建高质量网站?  如何挑选高效建站主机与优质域名?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  再谈Python中的字符串与字符编码(推荐)  如何选择适合PHP云建站的开源框架?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  网站制作公司排行榜,抖音怎样做个人官方网站  如何撰写建站申请书?关键要点有哪些?  在线教育网站制作平台,山西立德教育官网?  无锡营销型网站制作公司,无锡网选车牌流程?  建站上市公司网站建设方案与SEO优化服务定制指南  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  简历在线制作网站免费版,如何创建个人简历?  制作网站的模板软件,网站怎么建设?  如何通过服务器快速搭建网站?完整步骤解析  c# 服务器GC和工作站GC的区别和设置  实例解析Array和String方法  实例解析angularjs的filter过滤器  广东专业制作网站有哪些,广东省能源集团有限公司官网?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  微课制作网站有哪些,微课网怎么进?  Python如何创建带属性的XML节点  高防服务器:AI智能防御DDoS攻击与数据安全保障  实惠建站价格推荐:2025年高性价比自助建站套餐解析  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  ,在苏州找工作,上哪个网站比较好?  python的本地网站制作,如何创建本地站点?  高防服务器租用首荐平台,企业级优惠套餐快速部署  如何通过虚拟主机快速完成网站搭建?  已有域名和空间如何搭建网站?  微信推文制作网站有哪些,怎么做微信推文,急?  如何高效利用200m空间完成建站?  建站之星ASP如何实现CMS高效搭建与安全管理? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。