斜率优化详解

斜率优化

[HNOI2008] 玩具装箱

状态转移方程:
f i = m i n ( f i , f j + ( s u m i + i − s u m j − j − L ) 2 ) i > j f_i=min(f_i,f_j+(sum_i+i-sum_j-j-L)^2){i>j} fi=min(fi,fj+(sumi+isumjjL)2)i>j
设A为 s u m i + i sum_i+i sumi+i,B为 s u m j + j + L + 1 sum_j+j+L+1 sumj+j+L+1

简化可得:
f i = m i n ( f i , f j + A 2 − 2 A B + B 2 ) f_i=min(f_i,f_j+A^2-2AB+B^2) fi=min(fi,fj+A22AB+B2)
稍微分解一下,有:
f i = f j + A 2 − 2 A B + B 2 f j + B 2 = 2 A B + f i − A 2 f_i=f_j+A^2-2AB+B^2 \\ f_j+B^2=2AB+f_i-A^2 fi=fj+A22AB+B2fj+B2=2AB+fiA2
f j + B 2 f_j+B^2 fj+B2 为点 y y y 2 A 2A 2A k k k B B B x x x f i − A 2 f_i-A^2 fiA2 b b b

考虑一个确定的点 ( B , f j + B 2 ) (B,f_j+B^2) (B,fj+B2) k = 2 A k=2A k=2A​ 的最小截距。

对于每个确定的 i i i,可令斜率为 h i h_i hi 的直线过每个决策点,都可求得一个截距。根据状态转移方程可知,其中截距最小的直线方程所经过的决策点即为左右决策。

斜率:

先看一张图:

  • 斜率(↑↑↑)

斜率就是坡度,是高度的平均变化率,用坡度来刻划道路的倾斜程度,也就是用坡面的切直高度和水平长度的比,相当于在水平方向移动一千米,在切直方向上升或下降的数值,这个比值实际上就表示了坡度的大小。

即:设 ( 0 , 0 ) (0,0) (0,0) 点为 a a a ( 3 , 0 ) (3,0) (3,0) 点为 b b b,则点 B B B 的斜率为 ∣ b − a ∣ B − b \frac{|b-a|}{B-b} Bbba​。

以下称 x j x_j xj x x x 轴的 j j j 点, y i y_i yi 为在 y y y 轴的 i i i 点。

在绝v额集合中筛选出部分决策,使得在 x j x_j xj 递增的顺序下,相邻的决策点所炼成的线段的斜率单调递增。对于任意连续的三个所选决策 j i − 1 , j i , j i + 1 j_{i-1},j_{i},j_{i+1} ji1,ji,ji+1,都有:
f j i − f j i − 1 x j i − x j i − 1 < f j i + 1 − f j i f j i + 1 − f j i \frac{f_{j_{i}}-f_{j_{i-1}}}{x_{j_i}-x_{j_{i-1}}}<\frac{f_{j_{i+1}}-f_{j_{i}}}{f_{j_{i+1}}-f_{j_i}} xjixji1fjifji1<fji+1fjifji+1fji
在对应坐标系中,相邻点之间连成的线段呈现出“下凸”形态,即为“凸包”。

  • 凸包(↑↑↑)

若斜率函数 h i h_i hi x j x_j xj 均为单调递增函数,随着 j j j 的递增,决策点的横坐标也单调递增,新决策必定会出现在整个凸包的最右端。又因为斜率函数具有单调性,所以每次需要求解的直线斜率 h i h_i hi 也单调递增。决策集合仅保留下凸曲线上相邻现代斜率大于 h i h_i hi 的剩余决策点,所以曲线最左端的决策点即为最优决策。

  • 最优决策、最优斜率、截距(设B点为最佳决策点)

根据如上性质,我们不难想出,用双端队列 q[l~r] 维护下凸曲线,队列中保存部分决策,对应下凸曲线上的决策点,满足 x i x_i xi​ 和 h i h_i hi​​ 都递增。

具体实施方案:
  • 为了保证队头即为最优决策,仅需保留下凸曲线上斜率大于 h i h_i hi 的点,从队头开始检查决策 q l q_l ql 和后续决策 q l + 1 q_{l+1} ql+1 对应点连接线的斜率。若该斜率小等于 h i h_i hi,则把 q l q_l ql 出队,继续检查寻得队头和后续决策,直至线段斜率大于 h i h_i hi
  • 直接取队头决策 j = q l j=q_l j=ql 为最优决策,进行状态转移。
  • 将当前状态 i i i 为新的决策从队尾插入。在插入前需要维护凸曲线性质,即三个决策点 q r − 1 , q r , i q_{r-1},q_r,i qr1,qr,i 对应的相邻线段需要满足斜率单调递增,否则吧决策 q r q_r qr 出队,继续检查 q r − 2 , q r − 1 , i q_{r-2},q_{r-1},i qr2,qr1,i,直至满足要求。设此操作一共进行了 n n n 轮,则最终需要判断的三个状态为 q r − n , q r − n + 1 , i q_{r-n},q_{r-n+1},i qrn,qrn+1,i

时间复杂度: O ( N ) O(N) O(N)

  • 若斜率函数 h i h_i hi 不满足单调性,则 x j x_j xj 为单调递增函数,队头不为最优决策,须保留整个下凸曲线,可在队列中二分查找,求出一个位置 k k k,使得:

∀ p < k ∀ q > k h p < h k < h q \forall\ p\ <\ k \\ \forall\ q\ >\ k \\ h_p<h_k<h_q  p < k q > khp<hk<hq

若满足以上条件,则 k k k 为最优决策。

时间复杂度: O ( n log ⁡ n ) O(n \log n) O(nlogn)

AC Code:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,l;
const ll MAXN=5e4+5;
ll q[MAXN],sum[MAXN],f[MAXN];
ll head=1,tail=1;
ll j;
inline ll x(ll j)//x坐标 
{return sum[j];
}
inline ll y(ll j)//y坐标 
{return f[j]+(sum[j]+l)*(sum[j]+l);
}
inline double slope(ll i,ll j)//计算 
{return (double)(y(j)-y(i))/(x(j)-x(i));
}
inline ll compute(ll i,ll j)//代价公式 
{return (sum[i]-sum[j]-l)*(sum[i]-sum[j]-l);
}
int main(){scanf("%lld%lld",&n,&l);l++;//因为一直都是-l-1,干脆直接变为 -(l+1) for(ll i=1;i<=n;i++){scanf("%lld",&sum[i]);sum[i]+=sum[i-1]+1;//前缀和 }q[tail]=0;for(ll i=1;i<=n;i++)//dp{while(head<tail&&slope(q[head],q[head+1])<=(sum[i]<<1))//出队首条件 head++;j=q[head];//队首 f[i]=f[j]+compute(i,j);//计算 while(head<tail&&slope(q[tail-1],q[tail])>=slope(q[tail-1],i))//出队末条件 tail--;q[++tail]=i;//最优决策入队 }printf("%lld\n",f[n]);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/347876.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【面向就业的Linux基础】从入门到熟练,探索Linux的秘密(二)

主要内容介绍可tmux和vim的一些常用操作&#xff0c;可以当作笔记需要的时候进来查就行。 文章目录 前言 一、tmux和vim 二、Linux系统基本命令 1.tmux教程 2. vim教程 3.练习 总结 前言 主要内容介绍可tmux和vim的一些常用操作&#xff0c;可以当作笔记需要的时候进来查就行…

双非本科一年20w,已是人中龙凤了

大家好&#xff0c;我是白露啊。 “双非本科一年20w已经是人中龙凤了”……吗&#xff1f; 牛客上刷到这条帖子&#xff0c;我一开始以为是一个钓鱼、引战贴。看完才觉得他说的很对&#xff0c;现在在求职选择工作的时候&#xff0c;网上都觉得得40万、50万&#xff0c;但当真…

Next.js Tailwind CSS UI组件

摘要&#xff1a; 官网 今天公司使用到一个前端ui框架——Next.js Tailwind CSS UI组件&#xff01;这从头构建一个AI驱动的前端UI组件生成器&#xff0c;生成Next.js Tailwind CSS UI组件&#xff1a; 1、用Next.js、ts和Tailwind CSS构建UI组件生成器Web应用程序。 2、用Copi…

LVGL欢乐桌球游戏(LVGL+2D物理引擎学习案例)

LVGL欢乐桌球游戏&#xff08;LVGL2D物理引擎学习案例&#xff09; 视频效果&#xff1a; https://www.bilibili.com/video/BV1if421X7DL

UFS协议入门-分层结构

写在前面:本文参考UFS jedec3.1,本文思维导图如下 1. 分层概述 UFS协议分为3层,从上至下分别是:应用层(UAP),传输层(UTP),互联层(UIC),具体结构如下图所示。 2.1 应用层 在应用层(UAP)中,包括:UFS指令集(UCS),设备管理器(Device Manager),任务管理器(Task Manager…

MeiliSearch-轻量级且美丽的搜索引擎

MeiliSearch-轻量级且美丽的搜索引擎 MeiliSearch 是一个功能强大、快速、开源、易于使用和部署的搜索引擎。它具有以下特点&#xff1a; 支持中文搜索&#xff1a;MeiliSearch 对中文有良好的支持&#xff0c;不需要额外的配置。高度可定制&#xff1a;搜索和索引都可以高度…

GPT-4o多模态大模型的架构设计

GPT-4o&#xff1a;大模型风向&#xff0c;OpenAI大更新 OpenAI震撼发布两大更新&#xff01;桌面版APP与全新UI的ChatGPT上线&#xff0c;简化用户操作&#xff0c;体验更自然。同时&#xff0c;全能模型GPT-4o惊艳亮相&#xff0c;跨模态即时响应&#xff0c;性能卓越且性价比…

计算机网络 期末复习(谢希仁版本)第3章

对于点对点的链路&#xff0c;目前使用得最广泛的数据链路层协议是点对点协议 PPP (Point-to-Point Protocol)。局域网的传输媒体&#xff0c;包括有线传输媒体和无线传输媒体两个大类&#xff0c;那么有线传输媒体有同轴电缆、双绞线和光纤&#xff1b;无线传输媒体有微波、红…

Flink的简单学习五

一 动态表与连续查询 1.1 动态表 1.是flink的支持流数据Table API 和SQL的核心概念。动态表随时间的变化而变化 2.在流上面定义的表在内部是没有数据的 1.2 连续查询 1.永远不会停止&#xff0c;结果是一张动态表 二 Flink SQL 2.1 sql行 1.先启动启动flink集群 yarn-see…

全球首创4090推理!昆仑万维开源Skywork-MoE模型

昆仑万维近期宣布开源了其2千亿参数规模的稀疏大模型Skywork-MoE。这个模型是基于他们之前开源的Skywork-13B模型中间checkpoint扩展而来的&#xff0c;并且宣称是首个完整应用MoE Upcycling技术的开源千亿MoE大模型。此外&#xff0c;它也是首个支持使用单台RTX 4090服务器&am…

SpringSecurity入门(一)

1、引入依赖 spring-boot版本2.7.3&#xff0c;如未特殊说明版本默认使用此版本 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId></dependency><dependency><g…

16 DTLS协议

加密解密基本概念 什么是非对称加密 什么是公钥 这个就是谁都能获得的钥匙什么是私钥 只有一个人能获得 非对称加密就是公钥上的锁&#xff0c;私钥才能打开&#xff0c;私钥上的锁公钥才能打开。比如说就是地下党接头的时候&#xff0c;把一个信息放在盒子里&#xff0c;然…

大数据概论总结

三次信息化浪潮 : 信息技术的支撑 : 存储设备容量不断增加 CPU的处理能力不断提高 网络带宽不断增加 数据产生方式的变革促成大数据时代的来临 运营式系统阶段用户原创内容感知式系统阶段 大数据发展历程 : 分为三个阶段 : 大数据的概念 : 1 . 数据量大 : 根据IDC作出…

每日一练:攻防世界:base64stego

base64stego&#xff1a; 打开压缩包发现被加密&#xff0c;用winhex查看&#xff0c;发现是伪加密&#xff0c;修改文件目录区的全局方式位标记&#xff0c;成功打开压缩包&#xff0c;得到一个文本 这里我想的有三种情况&#xff1a;1.直接base64解码&#xff0c;然后看解码…

【计网复习】应用层总结(不含HTTP和错题重点解析)

应用层总结&#xff08;不含HTTP和错题重点解析&#xff09; 应用层简介 应用层的主要功能常见的应用层协议小林对于应用层通常的解释 网络应用模型 客户端-服务器模型&#xff08;Client-Server Model, C/S&#xff09; 特点优点缺点应用场景 对等网络模型&#xff08;Peer-to…

第十五篇——条件熵和信息增益:你提供的信息到底值多少钱?

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 通过这篇文章&#xff0c;我知道了条件熵和信息增益&#xff1b;如果你试…

RabbitMQ-Stream(高级详解)

文章目录 什么是流何时使用 RabbitMQ Stream&#xff1f;在 RabbitMQ 中使用流的其他方式基本使用Offset参数chunk Stream 插件服务端消息偏移量追踪示例 示例应用程序RabbitMQ 流 Java API概述环境创建具有所有默认值的环境使用 URI 创建环境创建具有多个 URI 的环境 启用 TLS…

JVM对象分配和垃圾回收机制

一、对象创建 1.1 符号引用 new 创建一个对象&#xff0c;需要在JVM创建对象。 符号引用&#xff1a;目标对象采用一个符号表示&#xff0c;类A加载的时候&#xff0c;如果成员变量类B还没有被加载进来&#xff0c;采用一个符号&#xff08;字面量&#xff09;来表示&#x…

解密有道翻译响应数据末尾出现乱码问题的解决方法

运行解密响应数据程序&#xff1a; D:\Python\Python311\python.exe E:\baichuan\youdaos.py {"code":0,"dictResult":{"ce":{"word":{"trs"D:\Python\Python311\python.exe E:\baichuan\youdaospdm.pyD:\Python\Python31…

Linux 性能优化基础

文章目录 常见指标分类&#xff08;USE法&#xff09;常见性能工具CPU性能工具内存性能工具文件系统和磁盘I/O性能工具网络性能工具 根据指标找工具CPU性能内存性能文件系统和磁盘I/O网络性能 根据工具找指标CPU性能内存性能文件系统和磁盘I/O网络性能 CPU性能分析一般步骤内存…