差分数组

力扣题目

1109. 航班预订统计

差分数组大体说明

差分数组与前缀和思想类似,但解决的问题不太一样。

其要解决的问题是频繁对数组的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,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值