洛谷B3612 【深进1.例1】求区间和

题目描述

给定 n 个正整数组成的数列 a1​,a2​,⋯,an​ 和 m 个区间 [li​,ri​],分别求这 m 个区间的区间和。

输入格式

第一行,为一个正整数 n 。

第二行,为 n 个正整数 a1​,a2​,⋯,an​

第三行,为一个正整数 m 。

接下来 m 行,每行为两个正整数 li​,ri​ ,满足 1≤li​≤ri​≤n

输出格式

共 m 行。

第 i 行为第 i 组答案的询问。

输入输出样例

输入 #1

复制代码
4
4 3 2 1
2
1 4
2 3

输出 #1

复制代码
10
5

说明/提示

样例解释:第 1 到第 4 个数加起来和为 10。第 2 个数到第 3 个数加起来和为 5。

对于 50% 的数据:n,m≤1000 ;

对于 100% 的数据:1≤n,m≤,1≤ai​≤

暴力只能得40%,要用前缀和优化

cpp 复制代码
#include<iostream>
using namespace std;

int n, m;
const int N = 1e5+10;
int a[N];

int main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	
	cin>>n;
	for(int i=1; i<=n; ++i)
	{
		cin>>a[i];
		a[i] += a[i-1];  //前缀和 
	}
	cin>>m;
	
	while(m--)
	{
		int r, l;
		cin>>r>>l;
		
		int ans = 0;
		ans = a[l]-a[r-1];
		cout<<ans<<'\n';
	}
	
	return 0;
}
相关推荐
资深web全栈开发13 天前
LeetCode 3578:统计极差最大为 K 的分割方式数 - 深入浅出指南
算法·leetcode·前缀和·动态规划·滑动窗口
nju_spy18 天前
力扣每日一题(11.10-11.29)0-1 和 k 整除系列
python·算法·leetcode·前缀和·单调栈·最大公约数·0-1背包
AKDreamer_HeXY18 天前
AtCoder Beginner Contest 434 C-E 题解
c++·算法·前缀和·图论·差分·atcoder
不穿格子的程序员18 天前
从零开始写算法——普通数组类题:最大子数组和 & 合并区间(C++)
c++·算法·leetcode·前缀和·买卖股票机问题
资深web全栈开发18 天前
LeetCode 1590:使数组和能被 p 整除(前缀和 + 哈希表优化)
算法·leetcode·前缀和·算法优化·哈希表·go 语言·取模运算
Ayanami_Reii19 天前
进阶数据结构应用-一个简单的整数问题2(Fenwick-Tree 解法)
数据结构·算法·前缀和·差分·树状数组·fenwick tree
不穿格子的程序员19 天前
从零开始刷算法——字串与区间类经典题:前缀和 + 单调队列双杀
算法·前缀和·哈希表·双向队列·单调队列
_OP_CHEN1 个月前
算法基础篇:(四)基础算法之前缀和
c++·算法·前缀和·蓝桥杯·acm·icpc·算法竞赛
还是码字踏实1 个月前
基础数据结构之数组的前缀和技巧:和为K的子数组(LeetCode 560 中等题)
算法·leetcode·前缀和·哈希字典
前进的李工2 个月前
LeetCode hot100:560 和为k的子数组:快速统计法
python·算法·leetcode·前缀和·哈希表