码迷,mamicode.com
首页 > 其他好文 > 详细

前缀和与差分

时间:2020-02-28 21:04:51      阅读:57      评论:0      收藏:0      [点我收藏+]

标签:strong   color   矩阵   二维   序列   前缀和   数组   计算   部分   

# 一维前缀和
S[i] = a[1] + a[2] + ... a[i]
[l,r]区间的和 = a[l] + ... + a[r] = S[r] - S[l - 1]

# 二维前缀和
S[i, j] = 第 i 行、第 j 列格子左上部分所有元素的和

计算:s[i][j] = s[i-1][j] + s[i][j-1] - s[i-1][j-1] + a[i][j]

以(x1, y1)为左上角,(x2, y2)为右下角的子矩阵的和为
S[x2, y2] - S[x1 - 1, y2] - S[x2, y1 - 1] + S[x1 - 1, y1 - 1]

一维差分

原序列是a,将a看作是一个前缀和数组
B[i] = a[i] - a[i - 1]
给数组a区间[l, r]中的每个数加上c:
B[l] += c, B[r + 1] -= c

最后对B求前缀和就可以得到a

# 二维差分

原序列是a[][],将a[][]看作是一个前缀和数组,

b是a 的差分数组

(x1,y1)是矩阵的起始,(x2,y2)是矩阵的终点

b[x1][y1]+= c;
b[x2+1][y1]-=c;
b[x1][y2+1]-=c;
b[x2+1][y2+1]+=c;

 

前缀和与差分

标签:strong   color   矩阵   二维   序列   前缀和   数组   计算   部分   

原文地址:https://www.cnblogs.com/hhyx/p/12378679.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!