这是一道DP题...我居然有那么半个小时思考非DP解决方案,实在是太弱了。

题意:给您若干山,您可以花费1代价削去1高度,求有k个山峰时的最小代价。

输出k = 1 ~ (n + 1) >> 1的答案。

这最后一个直接限制了我的DP思路。。。后来发现,DP本来就存了这些答案的..毒瘤。

状态表示是f[i][j][0/1],表示前i座山有j个山峰,自己是不是山峰。

比较奇特的是f[i][j][1]要从f[i - 2][j - 1][0/1]转移过来,自然少不了一些奇奇怪怪的特判...

 #include <cstdio>
#include <algorithm>
#include <cstring>
typedef long long LL;
const int N = ; LL f[N][N][]; // 0 no_hill 1 hill
int a[N], n; inline int val(int i) {
if(i < ) {
return ;
}
if(i == ) {
if(a[i] < a[i + ]) {
return ;
}
return a[i] - a[i + ] + ;
}
if(a[i - ] > a[i]) {
if(a[i + ] > a[i]) {
return ;
}
return a[i] - a[i + ] + ;
}
if(a[i + ] > a[i - ] - ) {
return ;
}
return a[i - ] - a[i + ]; /// error : a[i - 1] - a[i]
}
inline int vl(int i) {
if(i < ) {
return ;
}
if(a[i] < a[i + ]) {
return ;
}
return a[i] - a[i + ] + ;
}
inline int vx(int i) {
if(i > n) {
return ;
}
if(a[i] < a[i - ]) {
return ;
}
return a[i] - a[i - ] + ;
} int main() {
memset(f, 0x3f, sizeof(f));
scanf("%d", &n);
for(int i = ; i <= n; i++) {
f[i][][] = ;
}
for(int i = ; i <= n; i++) {
scanf("%d", &a[i]);
}
int k = (n + ) >> ; for(int j = ; j <= k; j++) {
for(int i = ; i <= n; i++) {
if(i == ) {
if(j == ) {
f[i][j][] = vx();
//printf("f[1][1][1] = %d\n", f[i][j][1]);
}
continue;
}
f[i][j][] = std::min(f[i - ][j][], f[i - ][j][]);
f[i][j][] = std::min(f[i - ][j - ][] + val(i - ), f[i - ][j - ][] + vl(i - )) + vx(i + );
//printf("f[%d][%d][0] = %d\n", i, j, f[i][j][0]);
//printf("f[%d][%d][1] = %d\n", i, j, f[i][j][1]);
}
}
/*
10
2 2 4 4 3 1 1 2 3 2
*/
for(int i = ; i <= k; i++) {
printf("%I64d ", std::min(f[n][i][], f[n][i][]));
} return ;
}

AC代码

CF 1013E Hills的更多相关文章

  1. CF 1013E Hills——隔项转移的DP

    题目:http://codeforces.com/contest/1013/problem/E 设 dp[ i ][ j ][ 0/1 ] 表示前 i 个位置,有 j 个山峰,第 i 个位置不是/是山 ...

  2. DP擎天

    DP! 黄题: 洛谷P2101 命运石之门的选择 假装是DP(分治 + ST表) CF 982C Cut 'em all! 树形贪心 洛谷P1020 导弹拦截 单调队列水题 绿题: 洛谷P1594 护 ...

  3. ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'

    凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...

  4. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  5. cf Round 613

    A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...

  6. ARC下OC对象和CF对象之间的桥接(bridge)

    在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...

  7. [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现

    1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...

  8. CF memsql Start[c]UP 2.0 A

    CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...

  9. CF memsql Start[c]UP 2.0 B

    CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...

随机推荐

  1. MyBatis的demo

    把以前写的关于mybatis的demo放在这边,以便查看. 目录结构: package com.test.mybatis.util; import java.io.IOException; impor ...

  2. 老男孩python学习自修第十三天【md5加密】

    示例代码如下: hashlib_test.py #!/usr/bin/env python # _*_ coding:UTF-8 _*_ import hashlib def genPasswd(na ...

  3. 一、.NET Core MVC 项目结构模板

    一.图文描述,开口干 二.文件结构:  wwwroot 首先,Razor Pages项目中多了一个wwwroot的文件夹,这个文件夹中,主要存放网站的静态资源,如css,网站图片资源文件,js文件,三 ...

  4. thinkphp视图中插入php代码

    性别: <?php if($item['sex'] == 1):?> 男 <?php else:?> 女 <?php endif;?> 错误:<?php ec ...

  5. controller层负责创建类传递类给service;service层负责逻辑编写调用dao层 将编写后的类传递到dao层,保证事务的正确性;dao层负责数据的持久化

    controller层负责创建类传递类给service:service层负责逻辑编写调用dao层 将编写后的类传递到dao层,保证事务的正确性:dao层负责数据的持久化

  6. Node.js机制及原理理解初步【转】

    一.node.js优缺点 node.js是单线程. 好处就是 1)简单 2)高性能,避免了频繁的线程切换开销 3)占用资源小,因为是单线程,在大负荷情况下,对内存占用仍然很低 3)线程安全,没有加锁. ...

  7. memcached安装报错 error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory解决

    我是从其他服务器scp来的memcached(~~~整个文件夹的那种,windows用多了的后遗症) 在准备运行 ./memcached -d -u root -l localhost -m 800 ...

  8. 傻瓜式搭建私人网络硬盘——owncloud安装指南

    百度云这个贱货天天删我资源,我已经忍无可忍了,于是想搭建一个owncloud来放我的里番.使用owncloud不仅安全,而且还可以在线播放,离线下载,功能相当强大. 然而·····网上查了一下,竟然无 ...

  9. Eliminate the Conflict HDU - 4115(2-sat 建图 hhh)

    题意: 石头剪刀布 分别为1.2.3,有n轮,给出了小A这n轮出什么,然后m行,每行三个数a b k,如果k为0 表示小B必须在第a轮和第b轮的策略一样,如果k为1 表示小B在第a轮和第b轮的策略不一 ...

  10. 【XSY2727】Remove Dilworth定理 堆 树状数组 DP

    题目描述 一个二维平面上有\(n\)个梯形,满足: 所有梯形的下底边在直线\(y=0\)上. 所有梯形的上底边在直线\(y=1\)上. 没有两个点的坐标相同. 你一次可以选择任意多个梯形,必须满足这些 ...