码迷,mamicode.com
首页 > 编程语言 > 详细

关于树状数组的区间修改和单点查询

时间:2018-10-08 19:37:56      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:https   sdn   差分   支持   bsp   text   操作   art   detail   

写在前面

之前一直不知道树状数组可以支持区间修改,所以写一篇博客记录一下。

首先给个小栗子:

如下图:

技术分享图片

利用差分的思路,就得到下图:

技术分享图片

那么如果我们要求将2~4的所有元素+2呢?我们就可以得到下图:

技术分享图片

可以发现,差分的第二项和第五项一个加了2,一个减了2,所以对于每次区间[l,r]操作,我们只需要在l和r+1的位置加、减操作值即可,证明也很简单,首先操作区间内的数的差肯定不会变,所以区间内的一段相同,因为第一项增加了一个值k,所以他与前面一项的差就增加了k,最后一项增加了k,最后一项的后一项与最后一项的差就减小了k,所以最后变化的就只有l和r+1位置的数,单点查询就只需要求前缀和即可。

--------------------- 本文来自 G21GLF 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/g21glf/article/details/82969676?utm_source=copy 

关于树状数组的区间修改和单点查询

标签:https   sdn   差分   支持   bsp   text   操作   art   detail   

原文地址:https://www.cnblogs.com/Ishtar/p/9756210.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!