继续看黄学长代码

原题:

P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京。他使用自己的压缩器进行压
缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中。P教授有编号为1...N的N件玩具,第i件玩具经过
压缩后变成一维长度为Ci.为了方便整理,P教授要求在一个一维容器中的玩具编号是连续的。同时如果一个一维容
器中有多个玩具,那么两件玩具之间要加入一个单位长度的填充物,形式地说如果将第i件玩具到第j个玩具放到一
个容器中,那么容器的长度将为 x=j-i+Sigma(Ck) i<=K<=j 制作容器的费用与容器的长度有关,根据教授研究,
如果容器长度为x,其制作费用为(X-L)^2.其中L是一个常量。P教授不关心容器的数目,他可以制作出任意长度的容
器,甚至超过L。但他希望费用最小.

第一行输入两个整数N,L.接下来N行输入Ci.1<=N<=50000,1<=L,Ci<=10^7

学过一点DP的都能想出的状态转移方程:f[i]=min(f[j]+(sum[i]-sum[j]+i-j-1-l)^2)

然后可以发现有些东西是怎么都不会变得,可以让s[i]=sum[i]+i,c=l+1

呢么这个方程就变成f[i]=min(f[j]+(s[i]-s[j]-c)^2)

然后就搞斜率优化

假设在i阶段有个一个优于j的决策k,呢么f[k]+(s[i]-s[k]-c)^2<=f[j]+(s[i]-s[j]-c)^2

呢么想要证明对于i后的所有状态t,要证明决策单调性,就是f[k]+(s[t]-s[k]-c)^2<=f[j]+(s[t]-s[j]-c)^2

因为s是固定的,所以s[t]可以表示为s[i]+v

f[k]+(s[i]+v-s[k]-c)^2<=f[j]+(s[i]+v-s[j]-c)^2

f[k]+ (s[i]-s[k]-c)^2 + 2*v*(s[i]-s[k]-c) + v^2 <= f[j]+ (s[i]-s[j]-c)^2 + 2*v*(s[i]-s[j]-c) + v^2

因为决策k是优于决策j的,所以f[k]<=f[j]

问了几个人都管不了(s[i]-s[k]-c)^2 QAQ,求大神指教QAQ

根据显然法可得,只需要证明 2*v*(s[i]-s[k]-c)<=2*v*(s[i]-s[j]-c),黄学长直接跳到这里

然后s[j]<=s[k]

然后求斜率优化

f[k]+(s[i]-s[k]-c)^2<=f[j]+(s[i]-s[j]-c)^2

展开略

(f[k]+(s[k]+c)^2-f[j]-(s[j]+c)^2)/(2*(s[k]-s[j]))<=f[i]

然后优化斜率

内个(s[i]-s[k]-c)^2怎么都想不明白,心好累qaq

代码:

 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int read(){int z=,mark=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')mark=-; ch=getchar();}
while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
return z*mark;
}
int n,m;
int dui[],tou=,wei=;
long long f[],s[];
long long fang(long long x){ return x*x;}
double get_ratio(int y,int x){ return ((f[x]-f[y]+fang(s[x]+m)-fang(s[y]+m))/(2.0*(s[x]-s[y])));}//斜率是右边-左边,所以这里参数先输入y,再输入x
void dp(){
dui[tou=]=;
for(int i=;i<=n;i++){
while(wei<tou && get_ratio(dui[wei],dui[wei+])<=s[i]) wei++;
int temp=dui[wei];
f[i]=f[temp]+fang(s[i]-s[temp]-m);
while(wei<tou && get_ratio(dui[tou],i)<get_ratio(dui[tou-],dui[tou])) tou--;
dui[++tou]=i;
}
}
int main(){//freopen("ddd.in","r",stdin);
cin>>n>>m; m++;
s[]=;
for(int i=;i<=n;i++) s[i]=s[i-]+read();
for(int i=;i<=n;i++) s[i]+=i;
dp();
cout<<f[n]<<endl;
return ;
}

【BZOJ1010】【HNOI2008】玩具装箱的更多相关文章

  1. bzoj1010[HNOI2008]玩具装箱toy 斜率优化dp

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 11893  Solved: 5061[Submit][S ...

  2. bzoj1010: [HNOI2008]玩具装箱toy(DP+斜率优化)

    1010: [HNOI2008]玩具装箱toy 题目:传送门 题解: 很明显的一题动态规划... f[i]表示1~i的最小花费 那么方程也是显而易见的:f[i]=min(f[j]+(sum[i]-su ...

  3. [bzoj1010][HNOI2008]玩具装箱toy_斜率优化dp

    玩具装箱toy bzoj-1010 HNOI-2008 题目大意:P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一 ...

  4. [BZOJ1010] [HNOI2008] 玩具装箱toy (斜率优化)

    Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1... ...

  5. [bzoj1010](HNOI2008)玩具装箱toy(动态规划+斜率优化+单调队列)

    Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有 的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1.. ...

  6. [BZOJ1010][HNOI2008]玩具装箱toy 解题报告

    Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1... ...

  7. BZOJ1010 [HNOI2008]玩具装箱toy

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  8. BZOJ1010 [HNOI2008]玩具装箱toy 动态规划 斜率优化

    原文链接http://www.cnblogs.com/zhouzhendong/p/8687797.html 题目传送门 - BZOJ1010 题意 一个数列$C$,然后把这个数列划分成若干段. 对于 ...

  9. 2018.09.05 bzoj1010: [HNOI2008]玩具装箱toy(斜率优化dp)

    传送门 一道经典的斜率优化dp. 推式子ing... 令f[i]表示装前i个玩具的最优代价. 然后用老套路. 我们只考虑把第j+1" role="presentation" ...

  10. 题解【bzoj1010 [HNOI2008]玩具装箱TOY】

    斜率优化动态规划可以用来解决这道题.同时这也是一道经典的斜率优化基础题. 分析:明显是动态规划.令\(dp[i]\)为前\(i\)个装箱的最小花费. 转移方程如下: \[dp[i]=\min\limi ...

随机推荐

  1. android 禁止viewPager 滑动

    public class ContainerViewPager extends MyViewPager { public ContainerViewPager(Context context, Att ...

  2. GPT分区基础知识及如何在GPT分区上安装WIN7

    大硬盘和WIN8系统,让我们从传统的BIOS+MBR模式升级到UEFI+GPT模式,现在购买的主流电脑,都是预装WIN8系统,为了更好的支持2TB硬盘,更快速的启动win8,预装系统都采取了GPT分区 ...

  3. android开机启动过程

    Android系统开机主要经历三个阶段: bootloader启动 Linux启动 Android启动 启动文件: 对于机器从通电到加载Linux系统一般需要三个文件:bootloader(引导文件) ...

  4. 排版字号对应多少pt

    各字号对应多少pt?初号= 42pt: 小初号= 36pt: 一号= 26pt: 二号= 22pt: 小二号= 18pt: 三号= 16pt: 四号= 14pt: 小四号= 12pt: 五号= 10. ...

  5. Reachability判断网络是否连接

    类似于一个网络状况的探针. [[NSNotificationCenter defaultCenter] addObserver: self selector: @selector(reachabili ...

  6. VS2010编译Qt5.4.0静态库

    http://www.kavenblog.com/?p=375 1.Qt的跨平台十分优秀,但是在Windows上是还是会有许多问题,其中之一就是动态链接库的问题,Qt程序的发布必须带一个体积不小的DL ...

  7. Git ~ 回到过去 , 进入未来 ~ Git

    概述 我们已经成功的添加了一个 readme.txt文件 , 现在是时候 继续工作了 , 于是 我们开始尝试一下 Git给我们所带来的便利下面修改read.txt 改成如下内容 为了尝试 Git 给我 ...

  8. PHP中目录的操作

    文件的操作:创建文件,删除文件,重命名文件rename(),移动/复制文件,读取,大小(PHP都有内置的函数) 目录的操作:创建目录(有),删除目录,复制目录,统计目录大小,遍历(自己定义函数) 一. ...

  9. Postfix之mail.cf

    1.# 2. 3.vi /etc/postfix/main.cf #vi编辑postfix配置文件 4.#找到如下配置项酌情修改 5.###### 6.myhostname =  mail.yourd ...

  10. GridView按钮事件

    1.html代码 <asp:TemplateField HeaderText="操作"> <ItemTemplate> <div style=&quo ...