算法复键——树状数组

树状数组怎么被我忘光了???

1. 干什么的

简单来说,树状数组支持一下两种操作:

  • 单点加
  • 查询前缀和 →\to→ 区间和查询

如果我们记录的是差分数列,那样子可以也可以实现:

  • 区间加
  • 单点查询

不一定是求和,所有满足交换律的都可以用树状数组实现。比如区间积、区间XOR


2. 怎么实现

现在以单点加、求前缀和为例:

我们定义一种操作 lowbit,即x二进制下最后一个1

加的时候,对后面所有都有影响,因此是+lowbit

求前缀和就回退就行

cpp 复制代码
struct TreeG {
	int cnt[N], i, ans; 
	void add(int x, int y) {
		while(x <= n) cnt[x] += y, x += x & -x; 
	}
	int qry(int x) {
		ans = 0; 
		while(x) ans += cnt[x], x -= x & -x; 
		return ans; 
	}
}s;

注意,树状数组的0位置不可用。如果要用到,请+1。

3. 还能干什么

对于树上问题,如果我们处理的是子树的某些和,同时树的形态不变。那么我们可以转成dfn序后用树状数组来维护。

上面的树也可以是Trie树,于是我们可以拿树状数组维护Trie树。

dp的过程中,可以直接把dp的某一维变成树状数组。

cdq分治的有一维是拿树状数组维护的。

相关推荐
H178535090962 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
不会就选b2 小时前
算法日常・每日刷题--<二分查找>3
算法
绿算技术3 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构
-森屿安年-3 小时前
63. 不同路径 II
c++·算法·动态规划
老余捞鱼3 小时前
线性回归实战:5步验证你的量化因子是否真有效
算法·金融·回归·线性回归·ai量化
想吃火锅10053 小时前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
码云数智-大飞3 小时前
RAII 与智能指针深度拆解
java·前端·算法
Dick5074 小时前
ROS2 常用命令表
人工智能·学习·算法·机器人
大鱼>4 小时前
地平线BPU部署实战:YOLOv8在J5/X3上的算法适配与性能优化
算法·yolo·性能优化