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 ...
随机推荐
- AngularJS路由使用案例
AngularJS路由使用案例: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"& ...
- laravel实现批量添加数据
在使用laravel eloquent进行数据库操作的时候惊讶的发现这货居然不支持批量添加,看到网上很多人在循环里进行数据库插入操作来实现批量添加,我想说这样做是很损失性能滴!好在框架的DB门面里的i ...
- 剑指offer(14)
题目: 操作给定的二叉树,将其变换为源二叉树的镜像. 思路: 这里有个细节,我们发现,6节点的子节点在操作之后并没有发生变化,所以等会我们在交换的时候,交换的不是节点的数值,而是整个节点. 另外我们进 ...
- MySQL索引管理及执行计划
一.索引介绍 二.explain详解 三.建立索引的原则(规范)
- linux audit审计(6)--audit永久生效的规则配置
定义reboot系统后,仍然生效的审计规则,有两种办法: 1.直接写入/etc/audit/audit.rules文件中,在service文件中需要加入ExecStartPost=-/sbin/aud ...
- 扩展运算符(spread)是三个点(…)
扩展运算符(spread)是三个点(…),将一个数组||类数组||字符串转为用逗号分隔的序列. js中用来对数组进行操作,把数组里面的东西统统拿出来 一.展开数组 //展开数组 let a = [1, ...
- codeforces347B
Fixed Points CodeForces - 347B A permutation of length n is an integer sequence such that each integ ...
- hdu-1711(kmp)
题意:给你两串数字,问你第二串数字第一次出现在第一串数字的位置,没有输出-1: 解题思路:其是就是字符串匹配,就是这里是数字匹配,把char数组改成int型就可以了: 代码: #include< ...
- 如何在Ubuntu 18.04上安装Django
Django是一个免费的开源高级Python Web框架,旨在帮助开发人员构建安全,可扩展和可维护的Web应用程序. 根据您的需要,有不同的方法来安装Django.它可以使用pip在系统范围内安装或在 ...
- Sql Server设置主键和外键
设置主键 https://jingyan.baidu.com/article/9158e0003349a7a2541228fd.html 设置外键 https://jingyan.baidu.com/ ...