数据结构-树状数组

数据结构-树状数组

树状数组是一种类似于前缀和的数据结构,但是前缀和的修改操作是 O(n)的,查询是 O(1) 的 。所以就有了树状数组这个数据结构,它的两种操作被中和了,都是 O(logn) 的。

C++ 复制代码
int nums[N];
//算出最后一位1的位置
int lowbit (int x) 
{    
    return x & -x;
}
//查询前缀和,时间复杂度O(logn)
int ask(int x)
{
    int res=0;
    for(;x;x-=lowbit(x)) res+=nums[x];
    return res;
}
//单点修改,时间复杂度O(logn)
int add(int x,int y)//nums[x]+y
{
    for(;x<=n;x+=lowbit(x)) nums[x]+=y;
}
相关推荐
星释2 分钟前
Rust 练习册 67:自定义集合与数据结构实现
数据结构·算法·rust
6***x5452 分钟前
C++在计算机视觉中的图像处理
c++·图像处理·计算机视觉·游戏引擎·logback·milvus
fpcc5 分钟前
跟我学C++中级篇——内存访问违例
c++
E***q53913 分钟前
C++内存对齐优化
开发语言·c++
D_evil__14 分钟前
[C++高频精进] 文件IO:文件操作
c++
前端小L1 小时前
图论专题(十九):DAG上的“关键路径”——极限规划「并行课程 III」
算法·矩阵·深度优先·图论·宽度优先
scx201310041 小时前
20251116 树状DP总结
算法·深度优先·图论
别动哪条鱼1 小时前
MP4转AAC转换器C++
c++·ffmpeg·音视频·aac
2301_807997382 小时前
代码随想录-day47
数据结构·c++·算法·leetcode
李日灐2 小时前
手搓简单 string 库:了解C++ 字符串底层
开发语言·c++