前缀和算法求数组中某个区间的

前缀和算法

对于一个数组,我们求数组中某个区间的和,如果通过遍历相加的话,时间复杂度为n。若分别求m个区间的和,则所需时间复杂度为m*n。因此我们可以使用前缀和算法优化它的时间复杂度。

我们可以利用一个数组,存储上面数组中0到每个位置区间的和。

如上图,下面的前缀和数组存储,上面区间和时是从数组1位置开始的,而不是数组0位置开始的。1位置存储的就是上面数组第一个数字到第一个数字区间的和,第2个位置存放的是上面数组第一个数字到第二个数组区间的和。这里前缀和数字从1开始存放,而不是从0开始存放,是为了后面处理边界的问题。

这里我们求前缀和数组中的值时,可以使用前缀和数组该位置对应的上面数组的值加上,前缀和数组该位置上一个位置里面的值,从而优化计算。如,求前缀和数组6下标的值,可以用上面数组第6个数加上前缀和下标5的值。

现在我们知道了从第1个数,到第n个数区间的和,那么我们要求如4到8之间的和,该怎么求呢?

第4个数和第8个数,在上面数组对应坐标为3和7,我们发现,该区间的和,就等于第1个数到第8个数的和减去第一个数的到第3个数的和。

因此转化为公式就是:

如求第n个数,到第m个数这个区间的和。

前缀和数组[m] - 前缀和数组[n-1]。

这里我们可以看出,为什么前缀和数组要从下标1开始存,比如求第1个数到第4个数区间和,带入公式为前缀和数组[4] - 前缀和数组[0]。

相关推荐
香蕉卜拿拿拿2 小时前
软件解耦与扩展的利器:基于C++与C#的插件式开发实践
c++
CoderCodingNo3 小时前
【GESP】C++五级真题(贪心和剪枝思想) luogu-B3930 [GESP202312 五级] 烹饪问题
开发语言·c++·剪枝
阿闽ooo4 小时前
深入浅出适配器模式:从跨国插头适配看接口兼容的艺术
c++·设计模式·适配器模式
oioihoii6 小时前
跨越进程的对话之从管道到gRPC的通信技术演进
c++
爱装代码的小瓶子7 小时前
算法【c++】二叉树搜索树转换成排序双向链表
c++·算法·链表
阳洞洞7 小时前
cmake中如何从include_directories中移除某个特定的头文件
c++·cmake
墨雪不会编程7 小时前
C++【string篇1遍历方式】:从零开始到熟悉使用string类
java·开发语言·c++
蓝色汪洋9 小时前
经典修路问题
开发语言·c++·算法
DARLING Zero two♡10 小时前
接入 AI Ping 限免接口,让 GLM-4.7 与 MiniMax-M2.1 成为你的免费 C++ 审计专家
开发语言·c++·人工智能
程序喵大人10 小时前
constexpr
开发语言·c++·constexpr