一维前缀和(差分与前缀和的下标都从1开始,避免出现越界)
算法思路:建立sum数组,sum[i]表示前i个数的总和(包括第i个),求l-r区间中数的和,则表示为sum[r]-sum[l-1]。
题目描述:
输入一个长度为n的整数序列。
接下来再输入m个询问,每个询问输入一对l, r。
对于每个询问,输出原序列中从第l个数到第r个数的和。
输入格式
第一行包含两个整数n和m。
第二行包含n个整数,表示整数数列。
接下来m行,每行包含两个整数l和r,表示一个询问的区间范围。
输出格式
共m行,每行输出一个询问的结果。
数据范围
1≤l≤r≤n
1≤n,m≤100000
−1000≤数列中元素的值≤1000
输入样例:
5 3
2 1 3 6 4
1 2
1 3
2 4
输出样例:
3
6
10
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
namespace IO{
inline LL read(){
LL o=0,f=1;char c=getchar();
while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
while(c>='0'&&c<='9'){o=o*10+c-'0';c=getchar();}
return o*f;
}
}using namespace IO;
const int N=1e5+7,base=1e9;
int sum[N];
int main(){
int n,q;
n=read(),q=read();
for(int x,i=1;i<=n;i++){//求sum要从1开始,从0开始就会越界
x=read();
sum[i]=sum[i-1]+x;
}
int l,r;
while(q--){
l=read(),r=read();
printf("%d\n",sum[r]-sum[l-1]);
}
return 0;
}