线段树 2

由于有两个操作,我们要对乘法和加法设置一个优先级

我们来看看先乘后加,lazy2表示乘数,lazy1表示加数(前者初始值为1,后者初始值为0

根据我们对lazy的理解,一个节点的和的真实值,为这个节点到根节点的路径中,对每一个节点依次先乘lazy2再加lazy1得到的最终结果

假设某一步时,和的中间结果为x

那么接下来,他就会变成y=xlazy2+lazy1,再走一步就会变成z=ylazy2+lazy1=xlazy2lazy2+lazy1lazy2+lazy1

所以在下传的时候,我们有lazy2×=lazy2lazy1=lazy1×lazy2+lazy1

具体可见洛谷提交代码

为什么先加后乘不行呢?

可以尝试一下按照上面的方法列式子,最终会列出来一个分数

update 2024.5.16

这道题目为什么不像上一道题目一样,每个节点只代表一个操作,要么是乘要么是加呢?

会发现这样没办法下传,因为会搞出来一个分数,此时就可以将一个节点表示的信息拓展成多维

posted @   最爱丁珰  阅读(4)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示