【算法学习笔记】前缀和与差分
前缀和与差分
本篇博客适合初学者阅读,如有不周之处,欢迎各位大佬指正!
-
0.背景
想象一下,你有一个数组( 很长很长de那种 )你需要求出给定一段区间的和,并有多次询问,作为初学者你是否要循环把他们都加起来呢?
-
1.正文
前缀和
前缀和是一个数列A通过递推能够求出来的信息之一,顾名思义就是某个数前面所有单元数值之和。他的公式如下
对于给定数列A,我们可以通过如下代码实现前缀和
for(rg int i=1;i<=n;i++){
S[i]=S[i-1]+A[i]
}
代码中的 就是前缀和的递推式
一个问题:如果我们想要求一个区间的和,我们应该如何实现?
由于代表数列的前缀和,我们想要求一个闭区间的和只需要去掉之前的所有部分就行了
所以我们就求出了的和
差分
对于一个给定数列,它的差分数列定义为
差分可以看做前缀和的逆运算
你可以认为的就是,的也是
利用差分,我们可以区间多次以复杂度区间修改一个数组
实现方法:
我们将原数组想象为高度不同的一片高楼(如下图)
//未完待续
本文作者:
本文链接:https://www.cnblogs.com/UssEnterprise/p/12085229.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步