[BZOJ2650]积木

题目大意:

有一排\(n\)个积木,第\(i\)个积木的高度为\(h_i\),定义混乱值为相邻两个积木高度之差的绝对值之和乘上系数\(c\)。可以花费\(t^2\)的代价将一个积木高度增加\(t\)。求花费与混乱值之和的最小值。

思路:

\(f_i\)表示前\(i\)个建筑,第\(i\)个高度不变。枚举上一个高度不变的积木\(j\),此时将中间一段最低点为\(k\),将这一段高度调整成一样的最优,转移方程为:

\[f_i=\min\{f_j+\sum_{k=j+1}^{i-1}(x-h_k)^2+(h_i+h_j-2x)c\}
\]

而其中\(k\)可以通过计算二次函数的对称轴得到。

考虑哪些\(j\)的转移会对答案产生贡献,由于只有在\(h_k\le\min(h_i,h_j)\)时增加积木高度答案才会比不增加更优,因此我们可以维护一个关于高度单调下降的栈,每次从栈顶取出一个\(k\),以及栈中第二个数\(j\)用来转移。时间复杂度\(\mathcal O(n)\)。

源代码:

#include<cmath>
#include<cstdio>
#include<cctype>
#include<climits>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
typedef long long int64;
const int N=1e6+2;
int n,k,h[N],stk[N],top;
int64 f[N],sum[N],psum[N];
inline int64 calc(const int &j,const int &i,int64 x) {
const int64 a=i-j-1;
const int64 b=-2*(sum[i-1]-sum[j])-(i!=n+1?k:0)-(j!=0?k:0);
const int64 c=psum[i-1]-psum[j]+(i!=n+1?1ll*k*h[i]:0)+(j!=0?1ll*k*h[j]:0);
x=std::max(x,(int64)round(-1.*b/a/2));
x=std::min(x,1ll*std::min(h[i],h[j]));
return a*x*x+b*x+c;
}
int main() {
n=getint(),k=getint();
h[0]=h[n+1]=INT_MAX;
for(register int i=1;i<=n;i++) {
h[i]=getint();
sum[i]=sum[i-1]+h[i];
psum[i]=psum[i-1]+1ll*h[i]*h[i];
}
for(register int i=1;i<=n+1;i++) {
f[i]=f[i-1]+(2<=i&&i<=n?1ll*std::abs(h[i]-h[i-1])*k:0);
for(;top>=0&&h[stk[top]]<=h[i];top--) {
if(top!=0) {
const int &j=stk[top-1],&k=stk[top];
f[i]=std::min(f[i],f[j]+calc(j,i,h[k]));
}
}
stk[++top]=i;
}
printf("%lld\n",f[n+1]);
return 0;
}

[BZOJ2650]积木的更多相关文章

  1. codevs 3288 积木大赛

    题目描述 Description 春春幼儿园举办了一年一度的"积木大赛".今年比赛的内容是搭建一座宽度为 n 的大厦,大厦可以看成由 n 块宽度为1的积木组成,第i块积木的最终高度 ...

  2. 洛谷P2409 Y的积木

    P2409 Y的积木 77通过 491提交 题目提供者zhouyonglong 标签云端评测 难度普及+/提高 提交  讨论  题解 最新讨论 这组数据几乎可以卡掉所有程- 第一个题解有点问题 求教大 ...

  3. NOIP2013积木大赛

    题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...

  4. vijos1059 积木城堡[n年浙江省队第X轮](背包的方案总数 or 01背包)

    描述 XC的儿子小XC最喜欢玩的游戏用积木垒漂亮的城堡.城堡是用一些立方体的积木垒成的,城堡的每一层是一块积木.小XC是一个比他爸爸XC还聪明的孩子,他发现垒城堡的时候,如果下面的积木比上面的积木大, ...

  5. noip2013 积木大赛

    题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...

  6. BZOJ 1109: [POI2007]堆积木Klo

    1109: [POI2007]堆积木Klo Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 948  Solved: 341[Submit][Statu ...

  7. [NOIP2013] 提高组 洛谷P1969 积木大赛

    题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...

  8. NOIp 2013 #1 积木大赛 Label:有趣的模拟

    题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...

  9. UVa 101 - The Blocks Problem(积木问题,指令操作)

    题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...

随机推荐

  1. ARMV8 datasheet学习笔记5:异常模型

    1.前言 2.异常类型描述 见 ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST 一文 3. 异常处理路由对比 AArch32.AArch64架 ...

  2. Centos socket TCP代码

    一.功能描述: 能够在Centos中创建TCP socket,实现Client给Server发送消息,Server能够Client发送消息. 二.代码如下: ①client代码: #include & ...

  3. 基于Golang设计一套微服务架构[转]

      article- @嘟嘟噜- May/26/2018 18:35:30 如何基于Golang设计一套微服务架构 微服务(Microservices),这个近几年我们经常听到.那么现在市面上的的微服 ...

  4. 实现自己的Koa2

    这部分的代码在https://github.com/zhaobao1830/koa2中demo文件夹中 Koa就是基于node自带的http模块,经过封装,监听端口,实现ctx(上下文)管理,中间件管 ...

  5. python之鸭子类型

    python不支持多态,也不用支持多态,python是一种多态语言,崇尚鸭子类型. 在程序设计中,鸭子类型是动态类型的一种风格,不是由继承特定的类或实现特定的接口,而是当前的方法和属性的集合决定,鸭子 ...

  6. VIM 报错

    syntax error: unexpected end of file if 没配对 在最后加 fi 试试 环境变量用不了 export PATH=/usr/bin:/usr/sbin:/bin:/ ...

  7. hdu4122

    题目很长,有点恶心,但实际上是个单调队列 没搞出来,题解 https://blog.csdn.net/lvshubao1314/article/details/46910271 #include< ...

  8. bootstrap 强调相关的类

    .text-muted:提示,使用浅灰色(#999) .text-primary:主要,使用蓝色(#428bca) .text-success:成功,使用浅绿色(#3c763d) .text-info ...

  9. 移除powerdesigner中Recent Files中无效链接的文件

    最近总算折腾清楚了,如何删除PowerDesigner中Recent Files或者recent models中不想显示的PDM文件链接: 解决方案: 将原文件的名称改变下,点击原先的文件链接,提示已 ...

  10. django 10.5 sqlite3迁移到mysql

    参考: http://www.voidcn.com/article/p-hesvaooz-ru.html 原文: python ./manage.py syncdb --database slave ...