前缀和与差分

一、引入:

对于给定的长度为 n 的数组 {a1,a2,...,an}你需要 m 次维护:

区间修改:将 a,b 这个区间中的全部元素增加 c ;

在全部修改完成后,直接输出最终的数组。

对于多次操作,如果是每次循环遍历操作,时间复杂度是O(n^2)级别; 这里就可以使用前缀和与差分。

二、原理:

1. 什么是前缀和:
css 复制代码
给定原数组 a[1⋯n],构造前缀和数组 s,其中 s[0]=0,s[i]=a[1]+a[2]+⋯+a[i]。
作用:**快速求区间 [l,r] 的和**,公式:**sum(l,r)=s[r]−s[l−1]。**
2. 什么是差分:
css 复制代码
给定原数组 a[1⋯n],构造差分数组 d,d[1]=a[1],d[i]=a[i]−a[i−1] (i>1)。
作用:快速给区间 [l,r] 统一加 / 减数值 v,操作:**d[l]+=v, d[r+1]−=v**;最后对差分数组**求一遍前缀和还原**原数组。
3. 复杂度分析:

前缀和与差分一般是放在一起用的。

三、代码模版:

js 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,m;
    cin>>n>>m;
    int arr[1005]={0};
    int dif[1005]={0};
    for(int i=1;i<=n;i++)cin>>arr[i];
    for(int i=1;i<=n;i++)dif[i]=arr[i]-arr[i-1];
    while(m--){
    	int a,b,c;
    	cin>>a>>b>>c;
    	dif[a]+=c;
    	dif[b+1]-=c;
	}
	for(int i=1;i<=n;i++)arr[i]=arr[i-1]+dif[i];
    for(int i=1;i<=n;i++)cout<<arr[i]<<" ";
	cout<<'\n';
    return 0;
}
相关推荐
weixin_461769401 小时前
通过数组和队列构造二叉树方法(用于算法测试),C++ vector不能直接使用null
数据结构·c++·算法·vector·nullptr·null
千寻girling2 小时前
一周没跑步了 ,今日跑步 5KM , 哑铃+健身 20min , 俯卧撑 30 个 ;
数据结构·c++·python·算法·leetcode·职场和发展·线性回归
CQU_JIAKE2 小时前
6.5aaaaa
算法·深度优先
学计算机的计算基2 小时前
2026 年 AI 助手三国杀:Claude Code vs 腾讯马维斯 vs MiniMax Mavis,我同时用了三周,结论很意外
java·人工智能·python·算法·langchain
GuWen_yue2 小时前
LeetCode 76 最小覆盖子串|JS 滑动窗口标准解法(逐行精讲)
javascript·算法·leetcode
sheeta19984 小时前
LeetCode 补拙笔记 日期:2026.06.07 题目:128. 最长连续序列
笔记·算法·leetcode
sheeta19984 小时前
LeetCode 补拙笔记 日期:2026.06.07 题目:1. 两数之和
笔记·算法·leetcode
柒和远方5 小时前
LeetCode 452. 用最少数量的箭引爆气球 —— 区间贪心经典:排序 + 扫描一箭穿心
javascript·python·算法