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