谈谈线段树中懒惰标记的设计
一·懒惰标记的重要性
线段树中,修改一段区间之内的值,是将其分成更小的区间与树中区间匹配,若无法匹配,则再分成更小的区间进行匹配。基于此,我们并不需要更改整棵树,只需要更改其中的一部分,更新掉的区间的子区间也不必更新,只要用懒标记标记即可,防止之后的查询错误。这样,时间复杂度便变小了,不然线段树的存在也就没有意义了,直接暴力不就好了。
二·懒惰标记对关键观察数据的影响
线段树中查询也是很大的一部分,思路差不多,就是将区间分成子区间处理,在这些子区间中,可能有些区间是并未更新到的(其父区间被更新并打上标记,由此便需要对懒惰标记进行下放,更新子区间,来确保查询的返回值正确,当然,这也是只要更新到需要查询到的区间即可结束,省时间。
三·懒惰标记的设计
线段树是对于修改的一种记录形式,所以懒标记在下放时,也只需要进行题目中所给出的操作即可,并将自己的懒标记消除,表示自己的儿子已更新,并给儿子打上标记,防止之后其儿子的儿子被用到,继续下放。
比如,洛谷P3372
__EOF__

本文作者:K_layna
本文链接:https://www.cnblogs.com/kezhuo/p/16437689.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/kezhuo/p/16437689.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术