bzoj 1200: [HNOI2005]木梳 DP
1200: [HNOI2005]木梳
Time Limit: 10 Sec Memory Limit: 162 MB
Submit: 266 Solved: 125
[Submit][Status]
Description


Input
第一行为整数L,其中4<=L<=100000,且有50%的数据满足L<=104,表示木板下侧直线段的长。第二行为L个正整数A1,A2,…,AL,其中1
Output
仅包含一个整数D,表示为使梳子面积最大,需要从木板上挖掉的格子数。
Sample Input
4 4 6 5 4 2 3 3 5
Sample Output

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
#define MAXN 110000
#define INFL 0x3f3f3f3f3f3f3f3fLL
typedef long long qword;
int h[MAXN];
int pp[MAXN][];;
qword dp[MAXN][][];
inline void deal(qword &x,qword y)
{
if (x<y)x=y;
}
int main()
{
freopen("input.txt","r",stdin);
int i,j,k,k2,x,y,z,n,m;
qword sum=;
scanf("%d",&n);
for (i=;i<=n;i++)
{
scanf("%d",h+i);
sum+=h[i];
for (j=h[i]-;j<=h[i]+;j++)
{
pp[i][++pp[i][]]=j;
if (i->=)pp[i-][++pp[i-][]]=j;
if (i+<=n)pp[i+][++pp[i+][]]=j;
if (i->=)pp[i-][++pp[i-][]]=j;
if (i+<=n)pp[i+][++pp[i+][]]=j;
}
}
for (i=;i<=n;i++)
{
sort(pp[i]+,pp[i]+pp[i][]+);
pp[i][]=unique(&pp[i][],&pp[i][pp[i][]+])-pp[i]-;
for (j=pp[i][]+;j<;j++)pp[i][j]=;
while (pp[i][] && pp[i][pp[i][]]>h[i])pp[i][pp[i][]--]=;
}
for (i=;i<=n+;i++)
for (j=;j<;j++)
for (k=;k<;k++)
dp[i][j][k]=-INFL;
for (i=;i<=pp[][];i++)
dp[][][i]=dp[][][i]=pp[][i];
for (i=;i<=n;i++)
{
for (j=;j<=pp[i-][];j++)
{
for (k=;k<=pp[i][];k++)
{
if (pp[i-][j]<pp[i][k])
{
deal(dp[i][][k],dp[i-][][j]+pp[i][k]);
}else if (pp[i-][j]>pp[i][k])
{
deal(dp[i][][k],dp[i-][][j]+pp[i][k]);
}else
{
deal(dp[i][][k],dp[i-][][j]+pp[i][k]);
deal(dp[i][][k],dp[i-][][j]+pp[i][k]);
}
}
}
}
qword ans=-INFL;
for (i=;i<=pp[n][];i++)
{
ans=max(ans,dp[n][][i]);
ans=max(ans,dp[n][][i]);
}
printf("%lld",sum-ans);
}
bzoj 1200: [HNOI2005]木梳 DP的更多相关文章
- 1200: [HNOI2005]木梳 - BZOJ
Description Input 第一行为整数L,其中4<=L<=100000,且有50%的数据满足L<=104,表示木板下侧直线段的长.第二行为L个正整数A1,A2,…,AL ...
- BZOJ 1200 木梳
Description Input 第一行为整数L,其中4≤L≤100000,且有50%的数据满足L≤104,表示木板下侧直线段的长.第二行为L个正整数A1,A2,…,AL,其中Ai≤108 Outp ...
- [BZOJ 3791] 作业 【DP】
题目链接:BZOJ - 3791 题目分析 一个性质:将一个序列染色 k 次,每次染连续的一段,最多将序列染成 2k-1 段不同的颜色. 那么就可以 DP 了,f[i][j][0|1] 表示到第 i ...
- [BZOJ 2165] 大楼 【DP + 倍增 + 二进制】
题目链接:BZOJ - 2165 题目分析: 这道题我读了题之后就想不出来怎么做,题解也找不到,于是就请教了黄学长,黄学长立刻秒掉了这道题,然后我再看他的题解才写出来..Orz 使用 DP + 倍增 ...
- BZOJ.3425.[POI2013]Polarization(DP 多重背包 二进制优化)
BZOJ 洛谷 最小可到达点对数自然是把一条路径上的边不断反向,也就是黑白染色后都由黑点指向白点.这样答案就是\(n-1\). 最大可到达点对数,容易想到找一个点\(a\),然后将其子树分为两部分\( ...
- BZOJ 4380 [POI2015]Myjnie | DP
链接 BZOJ 4380 题面 有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i]. 有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[i]个洗车店,且会选择这些店中最便宜的一个 ...
- BZOJ.5311.贞鱼(DP 决策单调)
题目链接 很容易写出\(O(n^2k)\)的DP方程.然后显然决策点是单调的,于是维护决策点就可以了.. 这个过程看代码或者别的博客吧我不写了..(其实是忘了) 这样复杂度\(O(nk\log n)\ ...
- 【BZOJ 3090】 树形DP
3090: Coci2009 [podjela] Description 有 N 个农民, 他们住在 N 个不同的村子里. 这 N 个村子形成一棵树.每个农民初始时获得 X 的钱.每一次操作, 一个农 ...
- bzoj 1030 fail树dp
dp[i][j][0]代表当前匹配到i号点走了j步且没到过单词节点,1代表到过,直接转移. #include<iostream> #include<cstdio> #inclu ...
随机推荐
- Nginx【第一篇】安装
一.简介 Nginx("engine x")是一款是由俄罗斯的程序设计师 Igor Sysoev 所开发高性能的 Web 和 反向代理 服务器,也是一个 IMAP/POP3/SMT ...
- MVC1笔记
/// ///直接返回 字符串的 Action方法,适用于 不需要返回大量 html代码的业务(类似于一般处理程序) /// public string Index() { return " ...
- inux设置普通用户无密码sudo权限
配置普通用户无密码sudo权限: root用户进入到Linux系统的/etc目录下 cd /etc 将sudoers文件赋予写的权限 chmod u+w /etc/sudoers 编辑sudoers文 ...
- java.sql.SQLException: Before start of result set
在使用JDBC查询数据库报了这么一个错误 CREATE TABLE `d_user` ( `id` int(10) NOT NULL, `name` varchar(10) DEFAULT NULL, ...
- 高级Magento模型 EAV
我们讲过Magento有两种模型,简单模型和EAV(Entity Attribute Value)模型.上一章我们讲过所有的Magento模型都是继承自Mage_Core_Model_Abstract ...
- ThinkPHP函数详解:A方法
A方法用于在内部实例化控制器,调用格式:A('[项目://][分组/]模块','控制器层名称')最简单的用法: $User = A('User'); 复制代码 表示实例化当前项目的UserAction ...
- Android测试分析3
一个基本的测试用例-- 如果是在eclipse中开发,那么需要在AndroidManifest.xml中加入如下两段代码: <uses-library android:name=" ...
- Android SDK目录含义介绍
Android SDK目录的具体结构: 1.add-ons:该目录下存放第三方公司为Android平台开发的附加功能系统. 2.build-tools:编译工具.保存着一些通用工具,比如aapt.ai ...
- onConfigurationChanged与OnCreate,究竟谁被调用的问题
在以前的版本中只要在AndroidManifest.xml文件中对activity指定android:configChanges="keyboardHidden|orientation&qu ...
- C语言之指针1.1数组
void main() { ]={,,,,,}; ;i++) { printf("%d\n",*(arr+i)); } } 输出结果时候123456