CF809D
平衡树优化神题,完全想不到平衡树能这么用!
一看这题散发着一股 DP 的清香。
反方向考虑 DP:
一个一个枚举太慢了!我们可以用平衡树维护所有
考虑每一个转移方程的影响,我们从整体来观察,而不是注意每一个
第一个转移方程,在扫完
(一开始就小于
于是我们直接在平衡树上插入
第二个转移方程:相当于把所有
这第二个转移方程,会把
总结一下:
-
把所有
的都加一。 -
插入
,注意这里顺序不能搞反,不然这个 会算进 的里面。而且我们发现,本来应该删除
的最小值,再插入 的(变成 ),但是因为 的都加一了,所以不用再删除 的最小值。 -
删除
的最小值。
最后的答案就是平衡树的大小。
看到这么多的区间操作,当然是用可爱的 FHQ_Treap 啦!
区间加一就用懒标记的方法。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!