CF 1013E Hills
这是一道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的更多相关文章
- CF 1013E Hills——隔项转移的DP
题目:http://codeforces.com/contest/1013/problem/E 设 dp[ i ][ j ][ 0/1 ] 表示前 i 个位置,有 j 个山峰,第 i 个位置不是/是山 ...
- DP擎天
DP! 黄题: 洛谷P2101 命运石之门的选择 假装是DP(分治 + ST表) CF 982C Cut 'em all! 树形贪心 洛谷P1020 导弹拦截 单调队列水题 绿题: 洛谷P1594 护 ...
- 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 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- 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 ...
- 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 ...
随机推荐
- mybatis二级缓存详解
1 二级缓存简介 二级缓存是在多个SqlSession在同一个Mapper文件中共享的缓存,它是Mapper级别的,其作用域是Mapper文件中的namespace,默认是不开启的.看如下图: 1. ...
- 【转】Git 代码行统计命令集
查看git上个人代码量 git log --author="username" --pretty=tformat: --numstat | awk '{ add += $1; su ...
- Golang的时间生成,格式化,以及获取函数执行时间的方法
最近都在通过完成一些列功能强化自己对常用api的熟悉. 然而关于时间的api几乎是最常用的api类型,所以总结一些常用的. 以YY-mm-dd HH:MM:SS.9位 输出当前时间: func mai ...
- spring boot session error
Error starting ApplicationContext. To display the conditions report re-run your application with 'de ...
- 每日一小时linux(1)--sysRq
参考https://www.ibm.com/developerworks/cn/linux/l-cn-sysrq/index.html SysRq 是什么 你是否遇到服务器不能通过 SSH 登录,也不 ...
- 使用kubeadm安装kubenetes
一.环境 关闭防火墙和selinux 禁用swap master节点安装 #1.配置源 cd /etc/yum.repos.d/wget https://mirrors.aliyun.com/dock ...
- MySQL磁盘写入策略以及数据安全性的相关参数
转载自:http://blog.itpub.net/22664653/viewspace-1063134/ innodb_flush_log_at_trx_commit和sync_binlog ...
- redis 中主从、哨兵和集群分片模式这三个有什么区别 ?
集群分片 比如 5主5从,也就是说 数据过来之后会均匀的分配到5台服务器上面,5台服务器上面的数据是不同的,但是每个服务器都有一个从服务器,上面的数据跟这一台主服务器的数据是一样的: 也就是说,对于这 ...
- hive 查询注意问题
1)对于hive内置的列,不是自己建的,在查询的时候需要添加反引号` 比如:`_mt_message`,别在这里犯错误, (2)南京的_mt_message是json的格式,所以可以直接使用:get_ ...
- C-Lodop对大小写敏感 不要使用大小混写
C-Lodop是对大小写敏感的,而以前的Lodop控件,对于大小混写有可能可以用,而目前由于高版本的火狐谷歌不再支持np插件,为了兼容所有浏览器,就要使用c-lodop,或像Lodop官网的样例一样, ...