【BZOJ2402】陶陶的难题II 分数规划+树链剖分+线段树+凸包

题解:

首先分数规划是很明显的

然后在于我们如何要快速要求yi-mid*xi的最值

这个是看了题解之后才知道的

这个是斜率的一个基本方法

我们设y=mid*x+z

那么显然我们可以把(x,y)插入到一个二维平面上

那么答案就是斜率为mid的与这个凸包相切的线

为什么要维护凸包呢,因为一旦下凸就不可能是最优解

二分logn 树剖log 线段树找节点log 凸包二分log

nlog^4  常数多小我也不知道

代码:

posted @   尹吴潇  阅读(166)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示