《征服数据结构》差分数组

摘要:

1,差分数组的介绍

2,二维差分数组的介绍

1,差分数组的介绍

差分数组主要是操作区间的,关于区间操作的数据结构比较多,除了前面讲的《稀疏表》,还有树状数组,线段树,伸展树Splay等。尤其是后面两个在信奥赛和蓝桥杯的比赛中用到的还是比较多的 ,之后我们也都会一一介绍、这里先看一下差分数组。

假设有这样一个问题,给你一个数组nums,先对区间a,b中每个元素加 3 ,在对区间c,d每个元素减 5 ...... ,这样非常频繁的区间修改,常规的做法可以一个个计算。

Java 代码:

go 复制代码
// 给闭区间[a,b]中的每个元素都增加 k 。
public void increment(int[] nums, int a, int b, int k) {
    for (int i = a; i <= b; i++) {
        nums[i] += k;
    }
}

C++ 代码:

go 复制代码
// 给闭区间[a,b]中的每个元素都增加 k 。
void increment(vector<int> &nums, int a, int b, int k) {
    for (int i = a; i <= b; i++) {
        nums[i] += k;
    }
}

频繁对数组的一段区间进行加减,如果一个个去操作,很明显效率很差,这个时候我们可以使用差分数组,差分数组就是原始数组相邻元素之间的差所构成的数组。定义差分数组dn,则 di = numsi − numsi−1 ,其中 d0 = nums0

可以看到原数组的元素就是差分数组的前缀和,如果要计算numsi,只需要把差分数组 d 的前 i 个元素相加即可。

ini 复制代码
nums[0] = d[0]
num[3] = d[0] + d[1] + d[2] + d[3]

有了差分数组,如果对区间 a,b 中的每个元素加 3 ,不需要在一个个操作,只需要在两端修改。如下图所示,可以看到原数组需要修改区间内的所有值,而差分数组只需要修改两个值即可,一个是给da加上 3 ,一个是给db+1减去 3 。

javascript 复制代码
d[a] += 3;
d[b+1] -= 3;// 注意不能越界
相关推荐
计算机安禾几秒前
【算法设计与分析】第29篇:启发式与元启发式搜索方法综述
java·数据库·算法
我叫袁小陌2 分钟前
数据结构详解与算法关联指南
算法
sleven fung3 分钟前
llama-cpp-python 本地部署入门
开发语言·python·算法·llama
头歌实践平台4 分钟前
C++面向对象 - 运算符重载的应用
开发语言·c++·算法
晚风予卿云月12 分钟前
《二分答案》算法练习
数据结构·c++·算法·二分·竞赛·算法随笔
普马萨特21 分钟前
搜索核心算法:从召回到排序
算法·搜索引擎
sheeta199821 分钟前
LeetCode 每日一题笔记 日期:2026.05.31 题目:2126. 摧毁小行星
笔记·算法·leetcode
INGNIGHT32 分钟前
984.不含 AAA 或 BBB 的字符串(贪心)
开发语言·算法·leetcode
代码中介商33 分钟前
哈希表:从O(1)查找到冲突解决全解析
数据结构·散列表
飞天狗11134 分钟前
2025第十六届蓝桥杯c/c++B组国赛题解
c语言·c++·算法·蓝桥杯