前缀和
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;