一、问题描述
输入一个长度为 n� 的整数序列。
接下来再输入 m� 个询问,每个询问输入一对 l,r�,�。
对于每个询问,输出原序列中从第 l� 个数到第 r� 个数的和。
输入格式
第一行包含两个整数 n� 和 m�。
第二行包含 n� 个整数,表示整数数列。
接下来 m� 行,每行包含两个整数 l� 和 r�,表示一个询问的区间范围。
输出格式
共 m� 行,每行输出一个询问的结果。
输入样例:
5 3
2 1 3 6 4
1 2
1 3
2 4
输出样例:
3
6
10
解题思路:用一个数组a[N]来储存输入的数据,用另一个数组b[N]来储存a[N]对应的前i项和。(b[i]=从a[1]加到a[i]的和)
代码实现:
#include<iostream> using namespace std; const int N=1e6+10; int a[N]; int b[N]; int main() { int n,m; cin>>n>>m; for(int i=1;i<=n;i++) { cin>>a[i]; b[i]=b[i-1]+a[i]; } for(int i=0;i<m;i++) { int x,y; cin>>x>>y; cout<<b[y]-b[x-1]<<endl; } return 0; }View Code
标签:输出,前缀,10,int,询问,整数,输入 From: https://www.cnblogs.com/zk126/p/17396310.html