前缀和与差分
前缀和和差分更像是一种思想
一维前缀和
一维前缀和的定义:s[i] = s[1] + s[2] + ... + s[i]
用处:快速算一段区间的和:s[l] + ... + s[r] = s[r] - s[l - 1]
二维前缀和
二位前缀和的定义
如图,前缀和数组中(x1, y1)的值是原数组红色矩阵中所有数的和
作用快速求一个子矩阵中所有数的和
初始化
如图,在前缀和数组中的(x, y)可以表示为:原数组(x, y) + 前缀和数组浅黄部分 + 前缀和数组深黄部分 - 前缀和数组橙色部分
若a为原数组,s为前缀和数组,则求前缀和的公式为:s[i][j] = a[i][j] + s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1];
求
左上角为(x1, y1),右下角为(x2, y2)的子矩阵中所有数的和为:
s[x2][y2] - s[x1 - 1][y2] - s[x2][y1 - 1] + s[x1 - 1][y1 - 1]
一维差分
差分是构造一个差分数组,使得差分数组的前缀和等于原数组
作用:快速给一段区间加上一个数,若差分数组为b,方式为:
void insert(int c)
{
b[l] += c;
b[r + 1] -= c;
}
差分数组构造方式:
因为上述公式的作用是维护此区间是个差分数组,所以可以把构造看成在只有一个数的区间插入一个c
二维差分
二维差分是在左上角(x1, y1),右下角(x2, y2)的子矩阵中同时加上一个数
二维差分的维护思想跟二维前缀和与一维差分类似
公式为:b[x1, y1] += c, b[x2 + 1, y1] -= c, b[x1, y2 + 1] -= c, b[x2 + 1, y2 + 1] += c;
标签:前缀,差分,x2,数组,y1,x1 来源: https://www.cnblogs.com/zyrddd/p/16225533.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。