斜率优化与决策单调性

斜率优化本质:维护凸包

基本上都是得到一个答案斜率式,然后后面的不会比前面的更优,找到这样的斜率临界点(二分),维护上/下凸包。

经常使用单调队列维护是因为斜率单调不降,单调栈是因为斜率单调不增。 x 坐标假如不单调递增的话就不能用线性数据结构维护,可以使用李超树/ cdq 分治。

决策单调性:决策点单调不降

例如,用单调队列维护的斜率优化,我们发现,假如一个点在这个时刻已经不是决策点,那么在之后也一定不是,所以它的决策点单调不降,才能使用决策单调性。

通常都是二分+单调栈处理出每个决策点管理区间或者分治找到 mid 点的最佳决策点,因为单调不增,分治维护。

注意,二分+单调栈需要贡献能 O(1) 求出。若不能可尝试用分治+双指针的方式。


__EOF__

本文作者F x o r G
本文链接https://www.cnblogs.com/xugangfan/p/15147685.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   FxorG  阅读(99)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示