斜率优化dp学习笔记 洛谷P3915[HNOI2008]玩具装箱toy
本文为原创???
作者写这篇文章的时候刚刚初一毕业……
如有错误请各位大佬指正
从例题入手
Step0:读题
Q:暴力?
如果您学习过dp
不难推出dp方程
设dp[i]表示放置前i个物品需要的最小价值
dp[i]=min(dp[j]+(sum[i]-sum[j-1]+i-j-L)^2)
sum[i]表示前缀和
暴力分有了!!恭喜!
下面我们引入斜率优化:
首先进行一个变形:
原来的式子可以变为:f[i]=min(f[j]+(sum[i]-sum[j]+i-j-L-1)^2)
令a[i]=sum[i]+i,b[i]=sum[i]+i+L+1
f[i]=min(f[j]+(a[i]-b[j])^2)
f[i]=min(f[j]+a[i]^2+b[j]^2-2*a[i]*b[j]) 初一公式!展开平方!
把b[j]看做x,f[j]+b[j]^2看做y
y=2*a[i]x+dp[i]-a[i]^2
这就是一条是直线的解析式!
y=kx+b,k=2*a[i],b=f[i]-a[i]^2
要找到一个点P(b[j],f[j]+b[j]^2)使得上面的斜率为2*a[i]的直线穿过这个点且与y 的轴截距最小
因为斜率k=2*a[i]是固定的,所以要求的就是最小的b,加上a[i]^2就是dp[i]的值。
很明显就是维护一个下凸壳
令a[i]=sum[i]+i
斜率单调递增!
code:推荐照着讲解看
#include<bits/stdc++.h>
#define ll long long
#define inf 0x7fffffff
#define un unsigned
#define ull un ll
#define int ull
using namespace std;
#define maxn 50009
int n,l,a[maxn];
int f[maxn],g[maxn];
int q[maxn];
int Q(int x){return x*x;}
double Get(un j,un k)//求斜率
{
return ((f[j]+Q(g[j])+*l*g[j])-(f[k]+Q(g[k])+*l*g[k]))/(double)(g[j]-g[k]);
}
signed main()
{
scanf("%llu%llu",&n,&l);
l++;
int s=,t=;
int K;
q[s]=;
for(int i=;i<=n;i++)
{
scanf("%llu",&g[i]);
g[i]=g[i]+g[i-];
}
for(int i=;i<=n;i++)g[i]+=i;
for(int i=;i<=n;q[++t]=i++)
{
K=g[i]<<;
while(s<t&&Get(q[s+],q[s])<=K) s++;
int j=q[s];
f[i]=f[j]+Q(g[i]-g[j]-l);
while(s<t&&Get(q[t],q[t-])>=Get(i,q[t]))t--;
}
printf("%llu\n",f[n]);
return ;
}
斜率优化dp学习笔记 洛谷P3915[HNOI2008]玩具装箱toy的更多相关文章
- 洛谷3195 [HNOI2008]玩具装箱TOY(斜率优化+dp)
qwq斜率优化好题 第一步还是考虑最朴素的\(dp\) \[dp=dp[j]+(i-j-1+sum[i]-sum[j])^2 \] 设\(f[i]=sum[i]+i\) 那么考虑将上述柿子变成$$dp ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY——斜率优化DP
题目:https://www.luogu.org/problemnew/show/P3195 第一次用斜率优化...其实还是有点云里雾里的: 网上的题解都很详细,我的理解就是通过把式子变形,假定一个最 ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY 斜率优化
Code: #include<cstdio> #include<algorithm> using namespace std; const int maxn = 100000 ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY(单调队列优化DP)
题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N的N件玩具, ...
- 洛谷 P3195 [HNOI2008]玩具装箱TOY
题意简述 有n个物体,第i个长度为ci 将n个物体分为若干组,每组必须连续 如果把i到j的物品分到一组,则该组长度为 \( j - i + \sum\limits_{k = i}^{j}ck \) 求 ...
- [洛谷P3195][HNOI2008]玩具装箱TOY
题目大意:有n个物体,大小为$c_i$.把第i个到第j个放到一起,容器的长度为$x=j-i+\sum\limits_{k-i}^{j} c_k$,若长度为x,费用为$(x-L)^2$.费用最小. 题解 ...
- 斜率优化DP学习笔记
先摆上学习的文章: orzzz:斜率优化dp学习 Accept:斜率优化DP 感谢dalao们的讲解,还是十分清晰的 斜率优化$DP$的本质是,通过转移的一些性质,避免枚举地得到最优转移 经典题:HD ...
- 洛谷 P3195 [HNOI2008] 玩具装箱
链接: P3195 题意: 给出 \(n\) 个物品及其权值 \(c\),连续的物品可以放进一个容器,如果将 \(i\sim j\) 的物品放进一个容器,产生的费用是 \(\left(j-i+\sum ...
- 洛谷P3195 [HNOI2008] 玩具装箱 [DP,斜率优化,单调队列优化]
题目传送门 题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N ...
随机推荐
- 1820:【00NOIP提高组】进制转换
#include<bits/stdc++.h>//十分简单(滑稽)的一道模拟题 using namespace std; ]={'A','B','C','D','E','F','G','H ...
- zabbix(12)使用Grafana
一.Grafana介绍 Grafana是一个跨平台的开源的度量分析和可视化工具,可以通过将采集的数据查询然后可视化的展示,并及时通知.它主要有以下六大特点: 1.展示方式:快速灵活的客户端图表,面板插 ...
- 简易版最长序列(map映射)
题目描述 给你一组数(未排序),请你写设计一个程序:求出里面个数最多的数.并输出这个数的长度. 例如:给你的数是:1. 2. 3. 3. 4. 4. 5. 5. 5 .6, 其中只有6组数:1, ...
- sql查询表的所有字段和表字段对应的类型
1.查询表的所有字段 select syscolumns.name from syscolumns where id=object_id('写上要查询的表名') 2.查询表的所有字段+表字段对应的类型 ...
- android: 使用android逆向助手反编译APK
第一步:下载逆向助手:(链接: https://pan.baidu.com/s/15jtoFDg9LWV80HREeyx5HA 提取码: k527 ) 第二步:将apk文件拷贝到逆向助手的apktoo ...
- ubuntu 12.04 nfs-server/client安装配置
由于opennebula的共享存储的方式需要nfs,为了opennebula 3.8在ubuntu 12.04上搭建做铺垫,先介绍下nfs server和client端的安装和配置. 1. nfs ...
- 一百四十一:CMS系统之根据板块过滤显示帖子
视图,根据传过来的板块id查数据 @bp.route('/')def index(): board_id = request.args.get('board_id', type=int, defaul ...
- 测试理论03-svn-缺陷及报告-jira
回顾--用例设计方法 边界值(三个点,使用步骤) 判定表(适用,四个组成部分,规则,使用) 因果图(适用,四个符号,使用) 正交表(定义,特性,L_n(m^k),因素,水平,使用,工具allpairs ...
- markdown 测试博客发布
这是一个测试页面 无序列表 tet test 有序列表 特使团 tetst 引用 This is a test 插入图片 插入链接 baidu 粗体 这是粗体 斜体 这是斜体 表格 IP VIP 备注 ...
- Linux下开发常用配置
JDK /etc/profile export JAVA_HOME=/usr/local/jdk1.8.0_181export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.ja ...