力扣题目
差分数组大体说明
差分数组与前缀和思想类似,但解决的问题不太一样。
其要解决的问题是频繁对数组的i到j位加相同的值的情况(每次i、j值可能不一样,要加的值也可能不一样)
如上图,对原始数组0到3位置+10,再对1到4位置+20,在对0到5位置-3,求最后数组的值。
常规做法是每次都遍历i到j,对相应位置的数都加上结果数。
我们来看看差分数组怎么做。
构造差分数组方法:diffArr[i] = arr[i] - arr[i-1],第0位的值则为自己本身。
vector<int> arr = {2,10,9,15,7,3};
vector<int> diffArr(arr.size(), 0);
// 第0位差分数组值为原始数组0位值
diffArr[0] = arr[0];
for (size_t i = 1; i < arr.size(); i++) {
diffArr[i] = arr[i] - arr[i - 1];
}
构造如上数组的差分数组
差分数组构造完毕后,现在0到3位都加10,