1 2 3 4 5 6 7 8 9
这样一个序列的前缀和是
1 3 6 10 15 21 36 45
很简单,可以直接得出公式
d表示前缀和数组,a表示原数组
d[i] = d[i - 1] + a[i];
前缀和可以快速求出某以区间的值
如:就上面的那个数据,你想求a[2, 5]这个区间里的和,可以用前缀和d[5] - d[1]
证明
a[2, 5]这个区间里的和是a[2] + a[3] + a[4] + a[5]
而d[5] = a[1] + a[2] + a[3] + a[4] + a[5]
d[1] = a[1];
d[5] - d[1] = a[2] + a[3] + a[4] + a[5]
完整代码:
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int a

这篇博客介绍了C++中前缀和的概念及其应用,通过公式解释了如何利用前缀和快速计算数组某一区间的和,并提供了完整的一维及二维前缀和代码示例,证明了其正确性。
最低0.47元/天 解锁文章
1334

被折叠的 条评论
为什么被折叠?



