前缀和

Posted fsh001

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前缀和相关的知识,希望对你有一定的参考价值。

前缀和

一维前缀和

思想

原数组从1开始存储数据,角标0为0;
S数组每一项存储a数组的前N项和;
这样a[l]到a[r]的和就为:S[r] - S[l-1]
(减去l-1,即剩下的就是l到r的和)

公式

S[i] = a[1] + a[2] + ... a[i]
a[l] + ... + a[r] = S[r] - S[l-1]

二维前缀和

思想

原数组从1开始存储数据,角标0为0;
S数组每一项存储a数组的前N项和;
求x1,y1,x2,y2的矩阵,
减去S[x1-1][y2]与S[x2][y1-1],
由于减去了S[x1-1][y1-1]两次,
最后结果应再加上这个面积一次

公式

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

以上是关于前缀和的主要内容,如果未能解决你的问题,请参考以下文章

VSCode创建自定义用户片段

JavaScript笔试题(js高级代码片段)

仅公开路由的 .NET OData API 子集(排除 API 返回 404)

POJ-2752(KMP算法+前缀数组的应用)

XML 属性未获取命名空间前缀

片段和活动之间的核心区别是啥?哪些代码可以写成片段?