[HNOI2008]玩具装箱toy(dp+斜率优化)

    斜率优化问题一般都是决策单调问题。对于这题能够证明单调决策。

令sum[i]=sigma(c [k] ) 1<=k<=i  ,  f[i]=sum[i]+i ,  c=L+1;

 首先我们能够写出转移方程  dp[i] = min( dp[j] + (f[i]-f[j]-c)^2 )  。令决策j1<j2。若决策j2更优有

 dp[j2]+(f[i]-f[j2]-c)^2<=dp[j1]+(f[i]-f[j1]-c)^2

能够得带 ((dp[j2]+f[j2]^2)-(dp[j1]+f[j1]^2)  )/(f[j2]-f[j1])<2*(f[i]-c)。

优于f[i]是递增的,所以对于t>i的点。决策j2总是比j1更优。那么j1实际上能够从决策集合中删除。后面的就能够用一个队列维护了。



<span style="font-size:14px;">#include <set>
#include <map>
#include <queue>
#include <stack>
#include <cmath>
#include <string>
#include <cctype>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iomanip>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long LL;
const int inf  = 0x3fffffff;
const int mmax =50010;
LL C[mmax];
LL L,c;
LL sum[mmax],f[mmax],dp[mmax];
LL sqr(LL x)
{return x*x;
}
double G(int x)
{return 1.0*f[x]*f[x]+dp[x];
}
double S(int x)
{return 2.0*f[x];
}
void calc(int i,int j)
{dp[i]=dp[j]+sqr(f[i]-f[j]-c);
}
int Q[mmax];
int main()
{int n;while(cin>>n>>L){c=L+1;sum[0]=0;f[0]=0;for(int i=1;i<=n;i++){scanf("%lld",&C[i]);sum[i]=sum[i-1]+C[i];f[i]=sum[i]+i;}int head=0,tail=-1;dp[0]=0;Q[++tail]=0;for(int i=1;i<=n;i++){while(head<tail){double tmp=1.0*(G(Q[head+1])-G(Q[head]))/(S(Q[head+1])-S(Q[head]));if(tmp<=f[i]-c)head++;elsebreak;}calc(i,Q[head]);while(head<tail){double tmp1=1.0*(G(Q[tail])-G(Q[tail-1]))/(S(Q[tail])-S(Q[tail-1]));double tmp2=1.0*(G(i)-G(Q[tail]))/(S(i)-S(Q[tail]));if(tmp1>=tmp2)tail--;elsebreak;}Q[++tail]=i;}printf("%lld\n",dp[n]);}return 0;
}
</span>


转载于:https://www.cnblogs.com/yangykaifa/p/6780636.html

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

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

相关文章

全球500强企业人力资源管理之道

美国杜邦的组织机构改革 美国杜邦公司(DuPont)是世界上最大的化学公司&#xff0c;建立至今&#xff0c;已近200年。杜邦公司所创设的组织机构&#xff0c;曾成为美国各公司包括著名大公司的模式&#xff0c;并反映了企业组织机构发展演变的一般特点。 拜耳公司人力资源管理…

mac idea实现全局替换

点击Edit ----- Find ----- Replace in Path 例如要把项目中的cc替换为aa 点击Replace All

linux下防火墙脚本,Linux系统如何修改防火墙配置

这篇文章主要介绍了Linux系统如何修改防火墙配置,文中通过示例代码介绍的非常详细&#xff0c;对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下改Linux系统防火墙配置需要修改 /etc/sysconfig/iptables 这个文件vim /etc/sysconfig/iptables在vim编辑器&…

现代希腊语字母表

转载于:https://www.cnblogs.com/zhangzujin/p/6782532.html

在俱乐部首页看不到的团队成员(更新中...)

截至到目前&#xff0c;可能因为暂时在博客园没有用户ID&#xff0c;在深圳.NET俱乐部首页看不到的几位成员是&#xff1a;1.小郑&#xff1a;没有留下任何信息&#xff0c;如果看到的话请补充。2.周文军&#xff1a;zhouwjsytech.com.cn &#xff1b;深圳时代高科&#xff1b;…

SHA-1算法c语言实现

安全哈希算法&#xff08;Secure Hash Algorithm&#xff09;主要适用于数字签名标准 &#xff08;Digital Signature Standard DSS&#xff09;里面定义的数字签名算法&#xff08;Digital Signature Algorithm DSA&#xff09;。对于长度小于2^64位的消息。SHA1会产生一个160…

Mac安装RocketMQ和可视化控制台教程

1:下载: http://rocketmq.apache.org/docs/quick-start/, 直接下载源代码版本 2:使用maven进行源码编译: mvn -Prelease-all -DskipTests clean install -U 3:环境配置 找到已经安装好的 jdk 位置&#xff0c;通过命令&#xff1a;/usr/libexec/java_home 在.zshrc中加入JAVA…

防止多重启动之调用Api [收集2005090201]

防止多重启动之调用Api (效果:第二次启动程序则前一进程的窗口跳到最前) using System.Threading;private const int SW_NORMAL 1; // see WinUser.h for definitions private const int SW_RESTORE 9; [DllImport("User32",EntryPoint"FindWindow")] …

交叉编译 linux库,linux交叉编译和动态库/链接

我正在努力为BeagleBoard开发。因此我安装了CodeSourcery SourceryG Lite Toolchain。我想使用opencv库。所以我将源码下载到我的Ubuntu devolepment系统中&#xff0c;并使用gcc编译为共享库并安装了该库。当我为x86架构构建helloworld应用程序时&#xff0c;一切都很好。现在…

poj 2109 Power of Cryptography

Power of CryptographyTime Limit: 1000MS Memory Limit: 30000KTotal Submissions: 18408 Accepted: 9292题目大意 给出两个数n&#xff0c;k要你求个数ans ans^nk关于题目中的数据范围全然能够用double完爆 不是必需用到二分高精度可是double类型尽管能表示10^(-307) ~ …

JAVA中文支持指南(Vera Yuanti)

在本指南中假设你已经安装了ttf-vera-yuan字体包&#xff0c;如果你还没有安装的话&#xff0c;请使用下面的命令&#xff1a; 代码: sudo apt-get install ttf-vera-yuan 1、首先安装Sun的J2SDK1.5包 代码: sudo apt-get install sun-j2sdk1.5 2、然后进入J2SDK的库目录 cd /u…

linux可以使用的远程管理,linux下可以使用以下()方法进行远程管理

linux下可以使用以下()方法进行远程管理更多相关问题1013的倒数是______&#xff1b;______和14互为倒数&#xff0e;12的倒数是______&#xff0c;______的倒数为47&#xff0e;试说明按年度计划分配率分配制造费用的特点、适用范围和优缺点。试说明材料费用分配的基本方法。什…

解决在工具栏Chrome图标上点击右键会显示“常去网站”和“最后关闭网站”的问题...

在工具栏Chrome图标上点击右键&#xff0c;可以“打开新窗口”或“打开新的隐身窗口”很方便&#xff0c;但是在其他电脑上尝试该操作时&#xff0c;发现有些情况下还会显示“常去网站”和“最后关闭网站”。如果关闭之&#xff1f; 经过摸索&#xff0c;发现方法如下&#xff…

JIRA介绍- 一个专业优秀的缺陷跟踪管理软件

一个令人惊奇的软件工具.JIRA易于安装和使用,良好的性能以及灵活的可配置性.JIRA的优势&#xff1a; 1.部署简单可以在很短的时间内部署JIRA&#xff0c;管理项目中的缺陷.2."零"学习时间 JIRA是B/S架构,简单易用&#xff0c;维护管理方便.3.跟踪项目质量 JIRA为您提…

linux centos 分区,linux centos 分区

1、查看硬盘[rootlocalhost ~]# fdisk -l2、使用fdisk命令分区[rootlocalhost ~]# fdisk /dev/sdb(此处为设备名称)常用命令&#xff1a;d 删除一个分区l 显示已知的文件系统类型。 82为Linux swap分区&#xff0c; 83为Linux分区m 显示帮助菜单n 新建分区p 显示分区列表q 不保…

Navicat工具安装及建表语句

Navicat工具安装安装&#xff1a;一路下一步即可Navicat工具使用连接&#xff1a; 连接名称&#xff1a;自定义 主机名称或IP地址&#xff1a;默认为localhost 端口&#xff1a;默认3306 用户名&#xff1a;默认root 密码&#xff1a;123456双击创建的连接-->变成绿色&#…