【深进1.例1】求区间和
题目描述
给定 个正整数组成的数列 和 个区间 ,分别求这 个区间的区间和。
对于所有测试数据,
输入格式
第一行,为一个正整数 。
第二行,为 个正整数
第三行,为一个正整数 。
接下来 行,每行为两个正整数 ,满足
输出格式
共 行。
第 行为第 组答案的询问。
样例 #1
样例输入 #1
4
4 3 2 1
2
1 4
2 3
样例输出 #1
10
5
提示
样例解释:第 到第 个数加起来和为 。第 个数到第 个数加起来和为 。
对于 的数据:;
对于 的数据:,
思路
前缀和是一种处理数组区间问题的常用方法,它可以在预处理阶段用的时间复杂度求出所有前缀和,然后在每次查询阶段用的时间复杂度求出任意一个区间的和。
首先,程序定义了两个长度为的数组和,分别用来存储输入的序列和序列的前缀和。然后,程序读入一个整数,表示序列的长度。
接着,程序进入一个循环,读入序列的每一个元素,并且在读入的同时,更新前缀和数组。这里,的值等于的值加上的值,也就是说,的值是序列的前个元素的和。
然后,程序读入一个整数,表示将要进行的查询的数量。之后,程序进入一个循环,对每一个查询进行处理。每一个查询包含两个整数和,表示要查询的区间的起点和终点。程序通过输出的值来得到查询的答案,这是因为的值是序列的前个元素的和,的值是序列的前个元素的和,所以他们的差就是序列的第个元素到第个元素的和。
AC代码
#include <iostream>
#define AUTHOR "HEX9CF"
using namespace std;
const int N = 1e7 + 7;
int n, m;
int a[N];
int s[N];
int main() {
s[0] = 0;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> a[i];
s[i] = a[i] + s[i - 1];
}
cin >> m;
for (int i = 1; i <= m; i++) {
int l, r;
cin >> l >> r;
cout << s[r] - s[l - 1] << endl;
}
return 0;
}