AcWing 算法基础课 前缀和、差分
前缀和
可以快速求部分和
有一维和二维的实现。
数组的下标最好从1开始
前缀和下标从0开始,以统一求a1~ai时的接口
差分
主要用于对某个区间同时进行加减
前缀和的逆运算
可以用o(n)的时间恢复原数组
d[i]=a[i]-a[i-1];
AcWing 797. 差分
#include<iostream>
using namespace std;
const int N=100010;
int n,m;
int a[N],d[N];
void insert(int l,int r,int c)
{
d[l]+=c;
d[r+1]-=c;
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>a[i];
d[i]=a[i]-a[i-1];
}
int l,r,c;
while (m -- )
{
cin>>l>>r>>c;
insert(l,r,c);
}
for(int i=1;i<=n;i++)
{
a[i]=d[i]+a[i-1];
cout<<a[i]<<' ';
}
return 0;
}
差分也有二维形式
同样也有,原矩阵是差分矩阵的前缀和。
d[i][[j]=a[i][j]-a[i-1][j]-a[i][j-1]+a[i-1][j-1];//构建差分矩阵
a[i][j]=a[i-1][j]+a[i][j-1]-a[i-1][j-1]+d[i][j];//恢复原矩阵;
//x1,y1~x2,y2插入c
insert(x1,y1,x2,y2,c)
d[x1][y1]+=c;
d[x2+1][y1]-=c;
d[x1][y2+1]-=c;
d[x2+1][y2+1]+=c;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人