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

csp信奥赛C++高频考点专项训练之前缀和差分 --【一维前缀和】:求区间和

csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维前缀和】:求区间和

题目描述

给定由n nn个正整数组成的序列a 1 , a 2 , ⋯ , a n a_1, a_2, \cdots, a_na1,a2,,anm mm个区间[ l i , r i ] [l_i,r_i][li,ri],分别求这m mm个区间的区间和。

输入格式

第一行包含一个正整数n nn,表示序列的长度。

第二行包含n nn个正整数a 1 , a 2 , ⋯ , a n a_1,a_2, \cdots ,a_na1,a2,,an

第三行包含一个正整数m mm,表示区间的数量。

接下来m mm行,每行包含两个正整数l i , r i l_i,r_ili,ri,满足1 ≤ l i ≤ r i ≤ n 1\le l_i\le r_i\le n1lirin

输出格式

m mm行,其中第i ii行包含一个正整数,表示第i ii组答案的询问。

输入输出样例 1
输入 1
4 4 3 2 1 2 1 4 2 3
输出 1
10 5
说明/提示
样例解释

1 11到第4 44个数加起来和为10 1010。第2 22个数到第3 33个数加起来和为5 55

数据范围

对于50 % 50 \%50%的数据:n , m ≤ 1000 n,m\le 1000n,m1000

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

思路分析

本题要求多次查询区间和,最朴素的做法是每次从lr累加,但最坏复杂度 O(n*m) 会超时(n,m ≤ 1e5)。
使用前缀和优化:预处理前缀和数组s,其中s[i] = a[1] + a[2] + ... + a[i],则区间[l, r]的和 =s[r] - s[l-1]
预处理 O(n),每次查询 O(1),总复杂度 O(n+m),满足要求。

代码实现

#include<bits/stdc++.h>usingnamespacestd;intn,m,l,r,a[100010],s[100010];// a存原序列,s存前缀和intmain(){cin>>n;// 读入长度for(inti=1;i<=n;i++){cin>>a[i];// 读入每个数s[i]=s[i-1]+a[i];// 计算前缀和,s[0]=0}cin>>m;// 读入查询次数while(m--){cin>>l>>r;// 读入区间端点cout<<s[r]-s[l-1]<<'\n';// 区间和 = 前缀和相减}return0;}

功能分析

  • 输入处理:读取序列长度 n,随后依次读取 n 个整数,同时在读取过程中动态构建前缀和数组s,使得s[i]保存前 i 个元素的和。
  • 查询处理:读取查询次数 m,对每组[l, r],利用前缀和公式s[r] - s[l-1]直接计算出区间和,并输出结果。
  • 性能:时间复杂度 O(n+m),空间复杂度 O(n),能够通过 100% 的数据(n,m ≤ 1e5)。

【完整系列请查看专栏】:
信奥赛C++普及组CSP-J一等奖通关刷题题单及题解:
https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转


各种学习资料,助力大家一站式学习和提升!!!

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"########## 一站式掌握信奥赛知识! ##########";cout<<"############# 冲刺信奥赛拿奖! #############";cout<<"###### 课程购买后永久学习,不受限制! ######";return0;}

【秘籍汇总】(完整csp信奥赛C++学习资料):

1、csp/信奥赛C++,完整信奥赛系列课程(永久学习):

https://edu.csdn.net/lecturer/7901 点击跳转

2、CSP信奥赛C++竞赛拿奖视频课:

https://edu.csdn.net/course/detail/40437 点击跳转

https://edu.csdn.net/course/detail/41081 点击跳转

3、csp信奥赛高频考点知识详解及案例实践:

CSP信奥赛C++动态规划:
https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转

CSP信奥赛C++标准模板库STL:
https://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转

信奥赛C++提高组csp-s知识详解及案例实践:
https://blog.csdn.net/weixin_66461496/category_13113932.html 点击跳转

4、csp信奥赛冲刺一等奖有效刷题题解:

信奥赛C++普及组CSP-J一等奖通关刷题题单及题解:
https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转

信奥赛C++提高组csp-j初赛&复赛真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转

信奥赛C++提高组csp-s初赛&复赛真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13125089.html 点击跳转

5、GESP C++考级真题题解:

GESP(C++ 一级+二级+三级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转

GESP(C++ 四级+五级+六级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转


GESP(C++ 七级+八级)真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13117178.html 点击跳转

· 文末祝福 ·

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"跟着王老师一起学习信奥赛C++";cout<<" 成就更好的自己! ";cout<<" csp信奥赛一等奖属于你! ";return0;}
http://www.jsqmd.com/news/852298/

相关文章:

  • CST仿真提速秘籍:用好Local Mesh,别再让简单结构拖慢你的仿真速度
  • 2026年白色冰箱怎么选?大白405成性价比首选,入手不亏! - 速递信息
  • 实测Taotoken聚合端点的响应延迟与稳定性观感分享
  • 从 .vimrc 配置到正则实战:打造你的 Vim 文本处理工作流
  • 从暴力枚举到O(N*2^N):用SOS DP(子集DP)优化状压题,LeetCode/Codeforces实战解析
  • 无王无帝定乾坤,来自田间第一人 布衣胸怀天下道
  • 猫抓cat-catch完全指南:5分钟掌握浏览器视频下载终极技巧
  • 写论文ai软件哪一款好?2026年实测6款写论文的AI软件排行榜,写论文不再是难事!
  • 73页精品PPT|大数据平台规划与数据价值挖掘应用咨询项目解决方案
  • 终极歌词批量下载指南:5分钟掌握163MusicLyrics高效歌词管理技巧
  • 在Ubuntu 22.04上,用SSH和HTTPS两种方式拉取OpenHarmony 4.1 Release源码(附完整命令)
  • 别再只复制代码了!手把手教你理解UniApp Map组件的定位、气泡与事件交互(附完整项目源码)
  • Agentic Design Patterns-模式4:反思(Reflection)的代码实现
  • 无王无帝定乾坤,来自田间第一人:第一大道耀古今
  • 如何快速掌握Pixi包管理:面向开发者的完整环境管理指南
  • 中文BERT-wwm情感分析实践:从95%到95.8%准确率的完整优化指南
  • 猫抓浏览器扩展:3分钟快速掌握网页资源嗅探终极技巧
  • 新手入门教程使用python在五分钟内完成taotoken大模型api的首次调用
  • 初创团队如何利用Taotoken Token Plan套餐控制AI实验成本
  • 2026亲测PanDownload解析百度网盘不限速下载:我用它拉满宽带的亲测教程
  • 别再死记硬背了!用这6个真实Java代码片段,5分钟搞懂UML类图关系
  • 电信信号处理利器:5分钟快速上手SpanDSP开源库完全指南
  • 从BERT微调失败到F1值跃升至0.91:DeepSeek垂直搜索在电子元器件BOM检索中的12小时攻坚实录
  • 无王无帝定乾坤,来自田间第一人:圣心出世安九州
  • 3种终极方案:在浏览器中解锁加密音乐文件的完整指南
  • 墙壁墙面桥梁建筑墙体裂缝宽度裂缝等级识别分割数据集labelme格式2996张3类别
  • CAD新手别再用直线硬画了!用PL命令的‘A’和‘R’快速搞定带半径的圆弧多段线
  • 2026低代码实测榜:6大主流平台功能+性价比PK,谁最值得选?
  • 沐曦股份 × 文心合作伙伴赛道Meetup 上海站|邀你共探国产算力优化实战
  • SAP FI新版本福音:不用开发,用OB28搞定会计凭证必填字段(附GS01建集避坑)