news 2026/6/15 14:06:32

算法——前缀和

作者头像

张小明

前端开发工程师

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/15 11:59:26

Sonic数字人玩王者荣耀?语音+动画同步

Sonic数字人玩王者荣耀&#xff1f;语音动画同步 在《王者荣耀》的激烈团战中&#xff0c;如果英雄突然开口解说战术&#xff1a;“这波我们集火射手&#xff01;”——你会不会以为是队友开了语音&#xff1f;但如果说话的是“貂蝉”本人&#xff0c;而她根本不是真人配音&…

作者头像 李华
网站建设 2026/6/15 13:56:11

力扣hot100:最小栈的实现

题目描述&#xff1a;解题思路&#xff1a;实现最小栈需要借用一个辅助栈 min_stack&#xff0c;用于存获取 stack 中最小值。算法流程&#xff1a;push() 方法&#xff1a; 每当push()新值进来时&#xff0c;如果 小于等于 min_stack 栈顶值&#xff0c;则一起 push() 到 min_…

作者头像 李华
网站建设 2026/6/15 13:50:36

为什么Sonic成为数字人制作的高效工具?三大优势揭秘

为什么Sonic成为数字人制作的高效工具&#xff1f;三大优势揭秘 在短视频井喷、虚拟主播遍地开花的今天&#xff0c;内容创作者面临一个现实难题&#xff1a;如何以最低成本、最快速度生成一条“会说话”的数字人视频&#xff1f;传统方案动辄需要3D建模、骨骼绑定、动作捕捉&…

作者头像 李华
网站建设 2026/5/18 19:46:27

Sonic数字人能否模仿明星?法律风险极高请勿尝试

Sonic数字人能否模仿明星&#xff1f;法律风险极高请勿尝试 在短视频与虚拟内容爆发式增长的今天&#xff0c;一个引人深思的问题浮出水面&#xff1a;我们是否能用一张照片和一段音频&#xff0c;就让AI“复活”一位明星&#xff0c;让他/她说出从未说过的话&#xff1f;技术上…

作者头像 李华
网站建设 2026/6/15 13:19:49

印度英语口音适配?口型差异较明显需优化

印度英语口音适配&#xff1f;口型差异较明显需优化 在虚拟主播、在线教育和短视频创作日益全球化的今天&#xff0c;数字人技术正从“能说话”迈向“说对话”的新阶段。尤其是当内容需要面向印度市场时&#xff0c;一个棘手的问题浮现出来&#xff1a;为什么同样的音频驱动模型…

作者头像 李华