前缀和与差分

前缀和

1、一维前缀和

公式:
1、预处理前缀和:S[i] = a[1] + a[2] + ... a[i]
2、求区间和:a[l] + ... + a[r] = S[r] - S[l - 1]

2、二维前缀和:

1、前缀和:s[i][j]=s[i-1][j]+s[i][j-1]-s[i-1][j-1]+a[i][j]
S[i, j] = 第i行j列格子左上部分所有元素的和
以(x1, y1)为左上角,(x2, y2)为右下角的子矩阵的和为:
2、求区间和:S[x2, y2] - S[x1 - 1, y2] - S[x2, y1 - 1] + S[x1 - 1, y1 - 1]

差分

1、一维差分

常见场景:给区间[l, r]中的每个数加上c:d[l] += c, d[r + 1] -= c

公式:d[i]=a[i]-a[i - 1]

2、二维差分

给以(x1, y1)为左上角,(x2, y2)为右下角的子矩阵中的所有元素加上c:

公式:

b[x1][y1] +=c;
b[x1][y2 + 1] -=c;
b[x2 + 1][y1] -=c;
b[x2 + 1][y2 + 1] +=c;
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容