[学习笔记]线段树分治

线段树分治是一种离线分治算法,主要思想是建立以询问的时间为叶节点的线段树,考虑修改对询问的影响(修改会影响一段时间上的询问)

用类似标记永久化的思想进行区间修改

(即把原修改影响的区间\([l,r]\)分成最多\(log(r-l+1)\)段,将操作挂在对应的节点上,不上传也不用下传)

最后\(dfs\)一遍,每进入一个节点就把节点上的操作(影响了全局)做了再往下递归,递归完成返回时将此节点的所有操作撤回(将全局改回原来的样子,类似回溯法)

那么对于有询问的叶节点,这个时间点的操作已经做完了(也就是会对这个时间点做贡献的修改都做了),再询问并输出即可

  • 注意

    到叶节点并不能想当然地直接返回,因为叶节点上可能也挂有操作(我们需要撤回才行)

据说这只是一种,还有的我也不会

来两道例题

posted @ 2019-09-24 20:51  陈星卿  阅读(293)  评论(0编辑  收藏  举报