差分
1|0本质思想
构造一个
差分是前缀和的逆运算。
2|0P2367 语文成绩
暴力模拟过不了,时间复杂度是
2|1差分思想
- 对于数组
,定义 的差分数组为 ,其中
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | |
---|---|---|---|---|---|---|---|---|
1 | 1 | 2 | 2 | 1 | 3 | 3 | 5 | |
1 | 0 | 1 | 0 | -1 | 2 | 0 | 2 |
-
对数组
求前缀和: -
可以发现
-
若将
增加 ,再对 数组求前缀和得到 数组,那么得到的 数组中 均增加 。 -
若将
减少 ,再对 数组求前缀和得到 数组,那么得到的 数组中 均减少 。 -
例如,对于一个全为
的差分数组 ,若将 增加 ,将 减少 ,得到的 数组如表所示:1 2 3 4 5 6 7 8 0 0 +1 0 0 -1 0 0 0 0 1 1 1 0 0 0
-
-
因此,将
数组中第 元素到第 元素增加 的修改操作,可以转化为将 增加 , 减少 ,最后再对 数组求前缀和。 -
这样,对于每次修改操作,只需要修改
个点,时间复杂度变为 。 -
同时,因为只有在最后一次修改操作才需要得到
数组的具体值,所以只需要所有修改操作结束后求一次前缀和即可。
2|2代码实现
3|0P3397 地毯
3|1差分思想
设数组
将
单独考虑一次覆盖操作,地毯左上角为
- 将
增加 。 - 将
减少 。 - 当地毯左上角为
右下角为 修改操作如图 。
3|2代码实现
__EOF__

本文作者:Kdlyh
本文链接:https://www.cnblogs.com/kdlyh/p/17893701.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/kdlyh/p/17893701.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下