线段树成段更新延迟标记理解
区间更新是指每次更新的时候更新的是一个区间里面的所有值,例如将区间[l,r]内的所有点都加或者减去一个数,或者替换成一个数字等等.因为区间更新每次更新的不止一个叶子节点,而叶子节点的值的更新肯定会影响到他的一系列的节点,所以假如每次都按照单点更新的思路将每一个叶子节点以及他的父节点都更新的话,那么工作量太大了并且时间肯定不会是log(n)会超时的。例如线段树总区间为[1,10],也就是这个树:
现在我们要更新[4,8]内的叶子节点的值,那么总共要更新的节点就会非常多。为了解决这个可能会超时的做法,引入了线段树中的延迟标记,这也是线段树的精华部分。延迟标记:每个节点除了常规的lft,rht,value外在增加一个标记,这个标记用于记录这个节点是否进行了某种修改(这种修改操作会影响其子节点),对于任意区间的修改,我们先按照区间查询的方式将其划分成线段树中的节点,然后修改这些节点的信息,并给这些节点标记上代表这种修改操作的标记。在修改和查询的时候,如果我们到了一个节点p,并且决定考虑其子节点,那么我们就要看节点p是否被标记,如果有,就要按照标记修改其子节点的信息,并且给子节点都标上相同的标记,同时消掉节点p的标记。这样一来成段更新的时候每次只需要更新有用的部分就可以了。
举例说明:当我们要将区间[1,3]的叶子节点的value增加2的时候,我们利用和区间查询一样的办法找到了区间[1,3],这时候我们把区间[1.3]的value值加上区间长度len