线段树(2) ----- hdu4578所得的线段树的效率探究

线段树是一种神奇的数据结构,这里简单说说他的效率到底快在哪

线段树的效率是由于他的二分而来的,然而二分之后却可以通过自己维护的值和子树与母树的逻辑关系可以得到任何起点和终点的线段才是线段树的奥妙 ; 

线段树的在线算法的特点在于他只存储部分数据,通过这部分数据在lgn内可以退出所需的数据 。 所以线段树一定要在update的过程中来维护获得所需数据,但是却不可以在给出一组询问后再回到节点上计算结果,因为那样,线段树就退化为了query为0(n) ; 也就大大的减少的效率; 所以一定要去考虑在任何子树上如何维护直接获得所需要的数据 ;


例如hdu4578

由于询问Q a b t为求a b 的数的t次方的和,也就是sigma(data[i]^t) (a<i<b) ; 

此题千万不要去想先维护树,确定add标记和muti标记 。 等到询问时再去下方到每一个叶节点然后求ans , 因为这样的话就TLE了 

此题我们可以去维护多颗数,因为t很小 , t<=3  ,那么我们就要维护3课线段树。第i课就是维护第k次幂的结果 ; 


还有一题离散线段树 , 用了55课线段树,这都是有可能的 。 



---------------------------------------成功在于独立思考和近乎疯狂的勤奋。。。--------------------------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值