码迷,mamicode.com
首页 > 其他好文 > 详细

线段树

时间:2017-10-29 18:41:50      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:rdl   att   一个   sdn   技术   src   技术分享   查询   考试   

我还是太菜了考试了几天什么lca,kmp,线段树都不会所以借此填坑线段树

分为两种模板:

技术分享

<1>

直接修改每个叶节点值

技术分享
查询

技术分享
<2>

将区间内叶子节点加上k

技术分享
查询技术分享

我们来对比一下,<2>和<1>相比,就多了如下一段代码,这段代码就是线段树思想的核心:偏移量顺便往下传递。相应修改的值也要做一下修改。

 

         int delta=tree[root].delta;  //根的偏移量。

    //往左右子树传递偏移量

         tree[root*2].delta+=delta;

         tree[root*2].maxx+=delta;

         tree[root*2+1].maxx+=delta;

         tree[root*2+1].delta+=delta;

         tree[root].delta=0;   //因为偏移量已经往下传,当前根的偏移量清0.

ATTENTION

    只有一个大区间的答案可以从左右两个小区间的答案中合并而来时,才可以用线段树。反之,如果一个大区间的答案不可以从左右两个小区间的答案中合并而来时,线段树就失去了意义。

线段树

标签:rdl   att   一个   sdn   技术   src   技术分享   查询   考试   

原文地址:http://www.cnblogs.com/Murs/p/7750518.html

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