news 2026/6/26 2:46:30

算法——前缀和

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法——前缀和

前缀和与差分的核心思想是预处理,可以在暴力枚举的过程中,快速给出查询的结果,从而优化时间复杂度。是经典的用空间替换时间的做法。

一、一维前缀和

快速求出数组中,某一段区间的和

1.先预处理出一个前缀和数组

①f [ i ] 表示:区间 [ 1 ,i ] 中所有元素的和

②计算公式:f [ i ] = f [ i - 1 ] + a [ i ]

2.利用前缀和数组

f [ l , r ] = f [ r ] - f [ l - 1 ]

【模板】静态区间和(前缀和)_牛客题霸_牛客网

描述

对于给定的长度为 nn 的数组 {a1,a2,…,an}{a1​,a2​,…,an​} ,你需要构建一个能够维护区间和信息的数据结构,使得其能支持:
∙ ∙ 区间和查询:输出 [l,r][l,r] 这个区间中的元素之和,即 ∑i=lrai∑i=lr​ai​ 。

输入描述:

第一行输入两个整数 n,q(1≦n,q≦106)n,q(1≦n,q≦106) 代表数组中的元素数量、操作次数。
第二行输入 nn 个整数 a1,a2,…,an(−109≦ai≦109)a1​,a2​,…,an​(−109≦ai​≦109) 代表初始数组。
此后 qq 行,每行输入两个整数 l,r(1≦l≦r≦n)l,r(1≦l≦r≦n) 代表区间和查询。

输出描述:

对于每一次询问,输出一行一个整数代表区间和。

示例1

输入:

3 2 1 2 4 1 2 2 3

输出:

3 6
#include <iostream> using namespace std; typedef long long LL; LL arr[1000000]; LL f[1000000];//前缀和数组 int main() { LL n,q; cin>>n>>q; int i=0; for(i=1;i<=n;i++) cin>>arr[i]; //处理前缀和数组 for(i=1;i<=n;i++) f[i]=f[i-1]+arr[i]; //处理q次询问 while(q--) { LL left,right; cin>>left>>right; cout<<f[right]-f[left-1]<<endl; } return 0; }

P1115 最大子段和 - 洛谷

题目描述

给出一个长度为 n 的序列 a,选出其中连续且非空的一段使得这段和最大。

输入格式

第一行是一个整数,表示序列的长度 n。

第二行有 n 个整数,第 i 个整数表示序列的第 i 个数字 ai​。

输出格式

输出一行一个整数表示答案。

输入输出样例

输入 #1复制

7 2 -4 3 -1 2 -4 3

输出 #1复制

4

说明/提示

样例 1 解释

选取 [3,5] 子段 {3,−1,2},其和为 4。

数据规模与约定
  • 对于 40% 的数据,保证 n≤2×103。
  • 对于 100% 的数据,保证 1≤n≤2×105,−104≤ai​≤104。
#include<iostream> using namespace std; typedef long long LL; const int N = 2e5 + 10; LL arr[N]; LL f[N]; int main() { LL n = 0; cin >> n; LL i = 0; for (i = 1;i <= n;i++) cin >> arr[i]; for (i = 1;i <= n;i++) f[i] = f[i - 1] + arr[i]; LL max_sum = f[1]; LL minPrev = 0; for (i = 1;i <= n;i++) { max_sum = max(max_sum, f[i] - minPrev); minPrev = min(minPrev, f[i]); } cout << max_sum; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 20:05:07

C++(1)C++基础

一、命名空间1.定义//1.普通的命名空间 namespace N1//N1为命名空间的名称 {//命名空间中的内容&#xff1a;//既可以定义变量//也可以定义函数int a;int Add(int left, int right){return left right;} }//2.命名空间可以嵌套 namespace N2 {int a;int b;int Add(int left, i…

作者头像 李华
网站建设 2026/6/19 14:51:22

脑机接口控制Sonic数字人?远期设想

脑机接口控制Sonic数字人&#xff1f;远期设想 在虚拟主播24小时不间断直播、AI教师为偏远地区学生授课、智能客服以拟真形象与用户对话的今天&#xff0c;数字人早已不再是科幻电影中的概念。但你有没有想过&#xff1a;如果有一天&#xff0c;我们不再需要说话&#xff0c;只…

作者头像 李华
网站建设 2026/6/25 22:36:04

如何举报滥用Sonic生成的不当内容?渠道公布

如何识别与举报滥用Sonic生成的不当内容&#xff1f;技术解析与应对指南 在虚拟主播一夜涨粉百万、AI换脸视频频现热搜的今天&#xff0c;数字人技术正以前所未有的速度重塑内容生态。其中&#xff0c;由腾讯联合浙江大学研发的轻量级口型同步模型Sonic&#xff0c;因其仅需一…

作者头像 李华
网站建设 2026/6/21 12:30:07

Sonic数字人参加TED演讲?模拟舞台表现力

Sonic数字人参加TED演讲&#xff1f;模拟舞台表现力 在一场虚拟的TED讲台上&#xff0c;聚光灯缓缓亮起。镜头前&#xff0c;一位神情专注的演讲者正娓娓道来&#xff0c;唇形精准地随着语句跳动&#xff0c;眼神自然流转&#xff0c;偶尔微笑点头&#xff0c;仿佛真实站在观众…

作者头像 李华
网站建设 2026/6/26 2:14:59

基于SpringBoot的自主推荐房源信息系统的研发毕设

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在研发一套基于SpringBoot框架的自主推荐房源信息系统&#xff0c;以满足现代房地产市场对个性化、智能化推荐服务的需求。具体研究目的如下&#xff1a…

作者头像 李华
网站建设 2026/6/19 0:10:37

Sonic数字人输出视频编码格式是H.264

Sonic数字人输出视频编码格式是H.264 在虚拟内容爆发式增长的今天&#xff0c;我们正见证一场由AI驱动的“数字人格革命”。从直播间里的虚拟主播&#xff0c;到企业宣传中的智能客服&#xff0c;再到教育课程中的卡通讲师——数字人不再只是科技展上的概念演示&#xff0c;而…

作者头像 李华