当前位置: 首页 > article >正文

洛谷P8218 【深进1.例1】求区间和(前缀和)

题目传送门
题目难度:普及一

【深进1.例1】求区间和

题目描述

给定 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,m105,ai104

输入格式

第一行,为一个正整数 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 1lirin

输出格式

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,m1000

对于 100 % 100 \% 100% 的数据: 1 ≤ n , m ≤ 1 0 5 1 \le n, m\le 10^5 1n,m105 1 ≤ a i ≤ 1 0 4 1 \le a_i\le 10^4 1ai104

题目分析:本题是一道简单题,需要用到前缀和的模板,下面介绍下前缀和。

前缀和:从名字上看,我们就大概能知道算法的作用。前缀,就是某位置之前的所有数,为该数的前缀,前缀和,就是对该位置前缀的元素进行求和。

一维前缀和
前缀和的模板其实非常简单,它更像是一种思想。前缀和思想可以快速地解决问题,看个例子:
假如给定一段序列,需要你求出 [l,r]区间的和,该如何求?最简单的方式就是通过 for 循环遍历一遍,时间复杂度为 O(N)而 前缀和算法 ,在O(1)的时间复杂度完成。

算法步骤:前缀和算法主要分为两步,预处理 和 查询 :假设 a,s 分别为 原数组 和 前缀和数组。

**预处理 :**预处理就是求 前缀和数组 。对于前缀和数组 s,其中元素满足 S[i]=a[1]+a[2]+a[3]…a[i] 求前缀和时,下标从 1 开始。大体过程如下:

for (int i = 1; i <= n; i++) {
        s[i] = s[i - 1] + a[i];
    }

前缀和数组每项 s[i] 是它的前一项 s[i−1] 加上原数组 a[i] 因为前缀和数组的前一项 s[i−1],是 a 数组中前 i−1 项的值嘛,所以求 s[i] 时只上 a[i] 就可以计算出来前 i项的前缀和了。
查询:
查询就是求给定区间 [l,r] 的值。现在由于求出了前缀和数组,那么查询时只要一步 S[r]−S[l−1],就可以求出结果。
在这里插入图片描述

最后就是代码部分:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e5 + 10;

int s[N],a[N];
int n,m;

ll read()
{
	ll s=0,f=1;
	char ch=getchar();
	
	while (ch<'0'||ch>'9')
	{
   	   if (ch=='-') f=-1;
	   ch=getchar();
	}
	while (ch>='0'&&ch<='9')
	{
	   s=s*10+ch-'0';
	   ch=getchar();
	}
	return s*f;
}

int main() {
   
    n = read();
    
    s[0] = 0;
    
    for(int i = 1; i <= n; i++) 
    {
    	a[i] = read();
    	s[i] = s[i - 1] + a[i];
	}
	
	m = read();
	
	while(m--)
	{
		int l = read(),r = read();
		cout<<s[r] - s[l-1]<<endl; 
	}
	
    return 0;
}




http://www.kler.cn/a/536726.html

相关文章:

  • 力扣 239.滑动窗口最大值
  • 超详细UE4(虚幻4)第一人称射击(FPS)游戏制作教程
  • 【GitHub】相关工具下载及使用
  • 32.日常算法
  • 使用Python创建、读取和修改Word文档
  • 爬虫学习笔记之Robots协议相关整理
  • ubuntu中 使用C++ FFmpeg拉取RTSP视频流
  • mapbox进阶,添加绘图扩展插件,绘制圆形
  • spring boot接收请求常用注解
  • 【华为OD机考】华为OD笔试真题解析(1)--AI处理器组合
  • 音视频的文件封装——AVI、MP4、MKV
  • [深度学习]神经网络-回归项目
  • Unity游戏(Assault空对地打击)开发(7) 爆炸效果
  • 前沿型CLI库——Clipanion
  • Qt 获取鼠标所在点颜色的RGB值,考虑多屏幕情况
  • 机器学习 - 容易混淆的目标函数和损失函数
  • 借助 Cursor 快速实现小程序前端开发
  • 探秘数据结构之单链表:从原理到实战的深度解析
  • ​零技术开始,但想用 Next.js 基于 React 构建一个类似 18Touch 的网站​
  • 【开源项目】数字孪生武汉~超经典智慧城市CIM/BIM数字孪生可视化项目——开源工程及源码
  • (文末提供数据集下载)ML.NET库学习001:基于PCA的信用卡异常检查之样本处理与训练
  • 如何在Windows上使用Docker
  • OCR与多模态大模型的关系
  • PDF转图片及拼接- ImageMagick
  • 【学习笔记】OpenGL的基础纹理贴图相关知识
  • HarmonyOS 5.0应用开发——ContentSlot的使用