news 2026/4/18 10:35:52

算法——前缀和

作者头像

张小明

前端开发工程师

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/4/18 5:41:57

MyBatisPlus用于存储Sonic用户生成记录?后端数据库设计建议

MyBatisPlus 与 Sonic 数字人生成系统的后端设计实践 在短视频、虚拟主播和 AI 教育内容爆发式增长的今天&#xff0c;如何快速、稳定地生成“会说话”的数字人视频&#xff0c;已成为许多创业团队和技术中台的核心命题。腾讯联合浙大推出的 Sonic 模型&#xff0c;正是这一趋势…

作者头像 李华
网站建设 2026/4/18 8:00:10

政府政策宣传视频?Sonic生成标准化播报

政府政策宣传视频&#xff1f;Sonic生成标准化播报 在政务新媒体内容日益高频、多元的今天&#xff0c;一个现实问题摆在面前&#xff1a;如何以低成本、高效率的方式持续输出权威、统一、可信的政策解读视频&#xff1f;传统拍摄模式受限于人力、场地和周期&#xff0c;往往一…

作者头像 李华
网站建设 2026/4/17 18:05:40

法语浪漫语调表现?emotion control待加强

Sonic数字人如何精准还原语音&#xff1f;情感表达仍待突破 在虚拟主播、在线教育和跨境电商内容井喷的今天&#xff0c;一个能“开口说话”的数字人早已不再是科幻电影里的设定。只需一张照片、一段音频&#xff0c;几秒钟内就能生成唇形精准对齐、表情自然的动态视频——这正…

作者头像 李华
网站建设 2026/4/18 8:03:08

QGraphicsRectItem的构成

1.QGraphicsRectItem的构成QGraphicsRectItem 是 Qt 框架中 QtWidgets 模块提供的一个图形项&#xff08;QGraphicsItem 的子类&#xff09;&#xff0c;用于在 QGraphicsScene 中表示一个矩形。它通常用于 2D 图形场景&#xff08;如绘图、UI 设计、游戏等&#xff09;。一、基…

作者头像 李华
网站建设 2026/4/15 2:37:46

音频时长不匹配导致穿帮?Sonic中duration参数必须严控

音频时长不匹配导致穿帮&#xff1f;Sonic中duration参数必须严控 在短视频内容爆炸式增长的今天&#xff0c;AI数字人已不再是实验室里的概念&#xff0c;而是真实活跃在直播间、教育平台和客服系统中的“打工人”。一张静态人脸 一段语音 会说话的虚拟主播——这看似魔幻的…

作者头像 李华
网站建设 2026/4/18 3:30:05

基于SpringBoot的展览馆综合系统的设计与实现毕设

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于SpringBoot框架的展览馆综合系统&#xff0c;以满足现代展览馆在信息化管理、智能化展示以及高效服务等方面的需求。具体研究目的如…

作者头像 李华