思路还是比较简单的 dp 吧,但是就是想不出来…甚至类似的方程都被自己推翻了

Description

Welcome to Innopolis city. Throughout the whole year, Innopolis citizens suffer from everlasting city construction.

From the window in your room, you see the sequence of \(n\) hills, where \(i\)-th of them has height \(a_i\). The Innopolis administration wants to build some houses on the hills. However, for the sake of city appearance, a house can be only built on the hill, which is strictly higher than neighbouring hills (if they are present). For example, if the sequence of heights is \(5,4,6,2\), then houses could be built on hills with heights \(5\) and \(6\) only.

The Innopolis administration has an excavator, that can decrease the height of an arbitrary hill by one in one hour. The excavator can only work on one hill at a time. It is allowed to decrease hills up to zero height, or even to negative values. Increasing height of any hill is impossible. The city administration wants to build \(k\) houses, so there must be at least \(k\) hills that satisfy the condition above. What is the minimum time required to adjust the hills to achieve the administration's plan?

However, the exact value of \(k\) is not yet determined, so could you please calculate answers for all \(k\) in range \(1\le k\le \left\lceil\frac n2\right\rceil\)? Here \(\left\lceil\frac n2\right\rceil\) denotes \(n\) divided by two, rounded up.

Input

The first line of input contains the only integer \(n(1\le n\le 5000)\)—the number of the hills in the sequence.

Second line contains \(n\) integers \(a_i(1\le a_i\le 100\ 000)\)—the heights of the hills in the sequence.

Output

Print exactly \(\left\lceil\frac n2\right\rceil\) numbers separated by spaces. The \(i\)-th printed number should be equal to the minimum number of hours required to level hills so it becomes possible to build \(i\) houses.

Examples

input

5
1 1 1 1 1

output

1 2 2

input

3
1 2 3

output

0 2

input

5
1 2 3 2 2

output

0 1 3

Note

In the first example, to get at least one hill suitable for construction, one can decrease the second hill by one in one hour, then the sequence of heights becomes \(1,0,1,1,1\) and the first hill becomes suitable for construction.

In the first example, to get at least two or at least three suitable hills, one can decrease the second and the fourth hills, then the sequence of heights becomes \(1,0,1,0,1\), and hills \(1,3,5\) become suitable for construction.

题意

现在有 \(n\) 座连在一起的山,高度从左到右分别为 \(a_i\)。现在你有一台挖掘机,每分钟可以令某一个 \(a_i\) 减一。你可以在 \(a_i>a_{i-1}\) 且 \(a_i>a_{i+1}\) 的山峰 \(i\) 盖房子。问对于 \(1\le k\le \left\lceil\frac n2 \right\rceil\) 中的每个整数 \(k\),盖 \(k\) 栋房子至少需要多长时间。

题解

针对本题有一个贪心,也就是不会有相邻的两个山同时被挖。

因此对于每个 \(i\),如果不挖这个位置,那么 \(a_i\) 是可以直接用原数据的。还有一点推论,即当 \(i\) 位置盖房子时,它一定不会被挖。挖了只会影响左右两边使他们更矮,不会产生更优的答案。

令 \(f[i][j][0/1]\) 表示前 \(i\) 座山中,盖了 \(j\) 栋房子,第 \(i\) 座山是否盖了房子。

那么如果第 \(i\) 座山要盖房子,那么第 \(i\) 座山不会被挖,高度为 \(a_i\);同时,第 \(i-1\) 座山的高度最多为 \(a_i-1\)。但是为了如果第 \(i-2\) 座要盖房子,那么第 \(i-1\) 座山的高度最多为 \(\min(a_{i-2}-1,a_i-1)\);第 \(i-2\) 座山不盖房子时,第 \(i-1\) 座山的高度就只受 \(a_i​\) 影响了。

如果第 \(i\) 座山不盖房子,那么考虑第 \(i-1\) 座山盖不盖房子就可以了。如果不盖,直接转移;否则把第 \(i\) 座山拉低到 \(a_{i-1}-1\) 的高度。

此时不考虑对后面的影响,因为我们的阶段就是 \(i\) 座山。

那么用类似于增量法的思路时就可以当 \(i\) 是 \(n\) 来做,思路会清晰很多。

状态转移方程为

\[\begin{aligned}
&f[i][j][1]=\begin{aligned}\min(&f[i-2][j-1][0]+\max(0,h[i-1]-h[i]+1),\\\ &f[i-2][j-1][1]+\max(0,h[i-1]-\min(h[i-2],h[i])+1)\end{aligned}\\\
&f[i][j][0]=\begin{aligned}\min(&f[i-1][j][1]+\max(0,h[i]-h[i-1]+1),\\\ &f[i-1][j][0])\end{aligned}
\end{aligned}
\]

最后对于每个 \(k\),输出 \(\min(f[n][k][0],f[n][k][1])\) 即可。

时间复杂度 \(O(n^2)​\)。

Code

#include<cstdio>
#include<cstring>
int Min(int x,int y){return x<y?x:y;}
int Max(int x,int y){return x>y?x:y;}
int h[5050];
int f[5050][5050][2];
int main()
{
memset(f,0x3f,sizeof(f));
f[0][0][0]=0;//初始化
f[1][1][1]=0;
f[1][0][0]=0;
int n;
scanf("%d",&n);
for(int i=1;i<=n;++i)
scanf("%d",&h[i]);
h[0]=0x3fffffff;
for(int i=2;i<=n;++i)
{
f[i][0][0]=f[i-1][0][0];
for(int j=1;j<=(i+1)/2;++j)
{
f[i][j][1]=Min(f[i-2][j-1][0]+Max(0,h[i-1]-h[i]+1),
f[i-2][j-1][1]+Max(0,h[i-1]-Min(h[i],h[i-2])+1));
f[i][j][0]=Min(f[i-1][j][0],
f[i-1][j][1]+Max(0,h[i]-h[i-1]+1));
}
}
for(int i=1;i<=(n+1)/2;++i)
printf("%d ",Min(f[n][i][0],f[n][i][1]));
return 0;
}

CF1012C Hills 题解【DP】的更多相关文章

  1. [FJOI2007]轮状病毒 题解(dp(找规律)+高精度)

    [FJOI2007]轮状病毒 题解(dp(找规律)+高精度) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1335733 没什么好说的,直接把规律找出来,有 ...

  2. 【线型DP】CF1012C Hills 小山坡

    来了来了. 题目: 给你n个数,你一次操作可以把某一个数-1(可以减为负数),你的目标是使任意的k个数严格小于它旁边的两个数(第一个数只用严格小于第二个数,第n个数只用严格小于第n-1个数),问最少需 ...

  3. CF1012C Hills

    显然的DP是,dp[i][j][val] val是1e6的 简化 发现,其实决策很有限,最优解的i-1的val选择有限 题解 这里的一个trick是,f[i][j][0]转移不考虑a[i]和a[i-1 ...

  4. HDU 6787 Chess 2020百度之星 初赛三 T5 题解 dp

    传送门:HDU 6787 Chess Problem Description 你现在有一个棋盘,上面有 n 个格子,格子从左往右,1,-,n 进行标号.你可以在棋盘上放置恰好 m 个传送器,并且对于每 ...

  5. 牛客练习赛69 火柴排队 题解(dp)

    题目链接 题目大意 给你一个长为n(n<=5e3)的数组a.随机使得k个元素增加d.要你求多大的概率使得,这些数组元素的相对大小不发生改变 输出 n 行每行一个整数,第 i 行的整数表示 k=i ...

  6. 古韵之乞巧 题解 dp题

    [noip模拟赛1]古韵之乞巧   描述 闺女求天女,更阑意未阑. 玉庭开粉席,罗袖捧金盘. 向月穿针易,临风整线难. 不知谁得巧,明旦试相看. ——祖咏<七夕> 女子乞巧,是七夕的重头戏 ...

  7. Codeforces 1012C Hills【DP】*

    Codeforces 1012C Hills Welcome to Innopolis city. Throughout the whole year, Innopolis citizens suff ...

  8. Codeforces 691E题解 DP+矩阵快速幂

    题面 传送门:http://codeforces.com/problemset/problem/691/E E. Xor-sequences time limit per test3 seconds ...

  9. Codeforces 833B 题解(DP+线段树)

    题面 传送门:http://codeforces.com/problemset/problem/833/B B. The Bakery time limit per test2.5 seconds m ...

随机推荐

  1. Java 设计模式系列(十二)代理模式

    Java 设计模式系列(十二)代理模式 代理模式是对象的结构模式.代理模式给某一个对象提供一个代理对象,并由代理对象控制对原对象的引用. package com.github.binarylei.de ...

  2. Basic4android v3.00 发布

    这次发布的版本主要是增加了快速debuger. 在运行时,可以在IDE 里面随时修改代码,而不需要重新发布应用. 大大提高了开发效率. Basic4android v3.00 is released. ...

  3. Determining Whether Multitasking Is Available

    [Determining Whether Multitasking Is Available] Apps must be prepared to handle situations where mul ...

  4. jfinal框架教程

    jfinal框架教程 下面通过一个小例子了解jfinal的结构和特点 1.建数据库(我用的是oracle数据库,其他的相对也差不多) -- Create table create table CLAS ...

  5. python 命令行工具 fire

    简介 A library for automatically generating command line interfaces. Python Fire is a library for auto ...

  6. redis集群种类(转)

    原文:http://blog.csdn.net/c295477887/article/details/52487621 关于redis主从.哨兵.集群的介绍网上很多,这里就不赘述了. 一.主从 通过持 ...

  7. Centos 7 手把手教你使用YUM方式安装并配置Nginx+php7-fpm+MySQL

    需要准备的内容 一台纯净系统的服务器 远程连接服务器的工具 (我这里使用Xshell) 安装nginx 链接上服务器后执行 yum install nginx  这里需要输入y 后回车,开始安装ngi ...

  8. 与table有关的布局

    当IE8发布时,它将支持很多新的CSS display属性值,包括与表格相关的属性值:table.table-row和table-cell,它也是最后一款支持这些属性值的主流浏览器.它标志着复杂CSS ...

  9. 6、Docker Image

    6.1 什么是image 文件和meta data的集合(root filesystem) 分层的,并且每一层都可以添加.改变.删除文件,成为一个新的image 不同的image可以共享相同的laye ...

  10. threadpoolExecutor----自动执行任务

    使用threadpoolExecutor,主要是任务的提交的执行和获取结果. 提交任务的方法有: 1.submit 2.execute 3.queue的add 其中1和2的使用必须是threadpoo ...