题目
题目描述
给定 n n n 个正整数组成的数列 a 1 , a 2 , ⋯ , a n a_1, a_2, \cdots, a_n a1,a2,⋯,an 和 m m m 个区间 [ l i , r i ] [l_i,r_i] [li,ri],分别求这
m m m 个区间的区间和。对于所有测试数据, n , m ≤ 1 0 5 , a i ≤ 1 0 4 n,m\le10^5,a_i\le 10^4 n,m≤105,ai≤104
输入格式
第一行,为一个正整数 n n n 。
第二行,为 n n n 个正整数 a 1 , a 2 , ⋯ , a n a_1,a_2, \cdots ,a_n a1,a2,⋯,an
第三行,为一个正整数 m m m 。
接下来 m m m 行,每行为两个正整数 l i , r i l_i,r_i li,ri ,满足 1 ≤ l i ≤ r i ≤ n 1\le l_i\le r_i\le n 1≤li≤ri≤n
输出格式
共 m m m 行。
第 i i i 行为第 i i i 组答案的询问。
样例 #1
样例输入 #1
4 4 3 2 1 2 1 4 2 3
样例输出 #1
10 5
提示
样例解释:第 1 1 1 到第 4 4 4 个数加起来和为 10 10 10。第 2 2 2 个数到第 3 3 3 个数加起来和为 5 5 5。
对于 50 % 50 \% 50% 的数据: n , m ≤ 1000 n,m\le 1000 n,m≤1000;
对于 100 % 100 \% 100% 的数据: 1 ≤ n , m ≤ 1 0 5 1 \le n, m\le 10^5 1≤n,m≤105, 1 ≤ a i ≤ 1 0 4 1 \le a_i\le 10^4 1≤ai≤104
思路
用等差数列和思路。数组存储数列前n 项和
S
n
S_n
Sn,这时候明显区间[a,b]之和等于
S
b
−
S
a
−
1
S_b-S_{a-1}
Sb−Sa−1。
这里a-1原因是
S
a
S_a
Sa包含了第a项,而我们求的需要包含第a项,因此不能减掉该项。
代码
#include<iostream>
using namespace std;
long long int d[100001]={0};
int main(){
int temp,n,m;
cin>>n;
for(int i=1;i<=n;i++){
cin>>temp;
d[i]=d[i-1]+temp; //数组存储前n项和
}
cin>>m;
int a,b;
for(int i=0;i<m;i++){
cin>>a>>b;
cout<<d[b]-d[a-1]<<endl; //计算区间和等于S(b)-S(a-1)
}
}