370.区间加法
题目大意:给一个二维数组,其中每个数组长度为3,包含了更新信息.
一、直接法
解题思路:硬算即可.
二、差分数组
这才是本题要考察的方法,差分数组算法参考https://labuladong.gitee.io/algo/2/21/52/
简单来说用一个diff
数组记录nums前后元素的差值,即diff[i] = nums[i] - nums[i-1], i >= 1
,当nums
的i~j
区间整体加x(某个数)时,i~j
区间diff
是不变的,只有两端的diff
改变,利用这个性质减少运算量,最后再用nums[i] = nums[i-1] + diff[i]
还原
最后更新于