bananahill(NOIP模拟赛Round 8)
题目描述
香蕉川由座香蕉山组成,第i座山有它的高度
。小Z准备从左到右爬这里的恰好
座香蕉山,但他不希望山的高度起伏太大,太过颠簸,会让本就体育不好的他过于劳累。所以他定义了爬山的劳累度是所有爬的相邻的两座山的高度差的绝对值之和。小Z希望他劳累值最小,所以他想问这个劳累值最小能是多少?
输入输出格式
输入格式:
第一行两个整数,表示有
座山且他准备爬其中恰好
座山。
第二行个数,分别给出每座山的高度。
输出格式:
输出一个整数,表示最小的劳累值。
说明
样例中,小Z可以选择爬1.2.3三座山或者2.3.4三座山,劳累值为1+1=2
对于50%的数据,
对于100%的数据,
————————————————我是分割线——————————————————
好吧,我们切入正题,这题很显然就是一道DP题(这不是废话。。)
那么问题就在于我们能否写出O(n^2)或者是O(n^2logn)的DP呢?
如果我们用暴力显然是不行的。
因为我们如果假设f[i][j]表示爬了i座山,最后一座山为j,那么我们显然需要一个循环来枚举i,同样,也要枚举j,
但是由于我们要将DP方程向下推,我们还要枚举k(j+1<=k<=n)
这样就是O(n^3)期望得分50分
可是我们想做出O(n^2)DP的话,几乎是不可能的。
那么我们如果退而求其次,自然就是O(n^2logn),自然想到线段树。
我们可以通过线段树维护最值来优化DP
这道题目中最烦的就是绝对值
因为如果是绝对值就是说明有2种情况,我们无法在一棵线段树上处理。
所以对于f[i][j],我们自然列出DP方程。
f[i][j]=min(min(f[i-1][k]+num[k]-num[j](j<=k<=n)),min(f[i-1][k]-num[k]+num[j](1<=k<=j)))
然后我们就可以用两颗线段树优化min中的2个数啦!
下面贴代码
#include<cstdio>
#include<cstring>
#define ls k<<1
#define rs k<<1|1
#define M (1<<10)
#define MN 2005
#define min(a,b) ((a)<(b)?(a):(b))
#define inf 0x3f3f3f3f
using namespace std;
int n,m;
int qmin[M<<],qmax[M<<];
int f[MN][MN],num[MN];
void update(int k,int val1,int val2)
{
k+=M,qmin[k]=min(qmin[k],val1),qmax[k]=min(qmax[k],val2);
for(k>>=;k;k>>=)qmin[k]=min(qmin[ls],qmin[rs]),qmax[k]=min(qmax[ls],qmax[rs]);
}
int queh(int k)
{
int qaq=inf;
for(k+=M-;k!=;k>>=)
if(~k&)qaq=min(qaq,qmax[k^]);
return qaq;
}
int quel(int k)
{
int qaq=inf;
for(k+=M+;k!=;k>>=)
if(k&)qaq=min(qaq,qmin[k^]);
return qaq;
}
int main(){
memset(qmin,0x3f,sizeof(qmin));
memset(qmax,0x3f,sizeof(qmax));
memset(f,0x3f,sizeof(f));
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%d",&num[i]),f[][i]=;
for(int i=;i<=m;i++)
{
for(int j=;j<i;j++)update(num[j],f[i-][j]-num[j],f[i-][j]+num[j]);
for(int j=i;j<=n;j++)
{
f[i][j]=min(queh(num[j])-num[j],quel(num[j])+num[j]);
update(num[j],f[i-][j]-num[j],f[i-][j]+num[j]);
}
memset(qmin,0x3f,sizeof(qmin));
memset(qmax,0x3f,sizeof(qmax));
}
int ans=inf;
for(int i=m;i<=n;i++)
ans=min(ans,f[m][i]);
printf("%d\n",ans);
}
bananahill(NOIP模拟赛Round 8)的更多相关文章
- 水(NOIP模拟赛Round #10)
题目描述: 小Z有一个长度为的数列.他有次令人窒息的操作,每次操作可以使某个数字或.他当然是希望这些数字的乘积尽量小了.为了简化题目,你只需输出操作完成后的数列即可. ———————————————— ...
- 小红帽的画笔(NOIP模拟赛Round 7)
又到了神奇的模拟赛时间~ 真是丧~ 好吧我们来看看题目 小红帽是Pop star上最著名的人类画家,她可以将任何画出的东西变成真实的物品.赋予她这样神奇能力的正是她手上的画笔. 小红帽每次作画时,都需 ...
- YYH的营救计划(NOIP模拟赛Round 6)
题目描述 “咚咚咚……”“查水表!”原来是查水表来了,现在哪里找这么热心上门的查表员啊!YYH感动的热泪盈眶,开起了门…… YYH的父亲下班回家,街坊邻居说YYH被一群陌生人强行押上了警车!YYH的父 ...
- 题(NOIP模拟赛Round #10)
题目描述: 有一张的地图,其中的地方是墙,的地方是路.有两种操作: 给出个地点,询问这个地点中活动空间最大的编号.若询问的位置是墙,则活动空间为:否则活动空间为询问地点通过四联通能到达的点的个数.如果 ...
- 大(NOIP模拟赛Round #10)
题目描述: 小Z有个n个点的高清大图,每个点有且只有一条单向边的出边.现在你可以翻转其中的一些边,使他从任何一个点都不能通过一些道路走回这个点.为了方便,你只需输出方案数对取模即可.当在两个方案中有任 ...
- 战斗机的祈雨仪式(NOIP模拟赛Round 7)
[问题描述] 炎炎夏日,如果没有一场大雨怎么才能尽兴?秋之国的人民准备了一场祈雨仪式.战斗机由于拥有操纵雷电的能力,所以也加入了其中,为此,她进行了一番准备. 战斗机需要给自己的Spear of Lo ...
- 魔法使的烟花(NOIP模拟赛Round 7)
[问题描述] 魔法森林里有很多蘑菇,魔法使常常采摘它们来制作魔法药水.为了在6月的那个奇妙的晚上用魔法绽放出最绚丽的烟花,魔法使决定对魔法森林进行一番彻底的勘探. 魔法森林分为n个区域,由n-1条长度 ...
- 灰姑娘的水晶鞋(NOIP模拟赛Round 7)
[问题描述] 传说中的水晶鞋有两种颜色:左边的水晶鞋是红色,右边的是蓝色,据说穿上它们会有神奇的力量. 灰姑娘要找到她所有的n双水晶鞋,它们散落在一条数轴的正半轴上,坐标各不相同,每双水晶鞋还有一个权 ...
- YYH的球盒游戏(NOIP模拟赛Round 6)
题目描述 YYH有一些总共有种颜色的球,他有颜色的球个.他同样有个盒子,第个盒子能放个球. 他的目标是把这个球按规则放进个盒子里: 对于一个盒子,对于每种颜色的球至多只能放个. 把颜色为的球放进盒子, ...
随机推荐
- 开放定址法——线性探测(Linear Probing)
之前我们所采用的那种方法,也被称之为封闭定址法.每个桶单元里存的都是那些与这个桶地址比如K相冲突的词条.也就是说每个词条应该属于哪个桶所对应的列表,都是在事先已经注定的.经过一个确定的哈希函数,这些绿 ...
- POJ:3977-Subset(双向搜索)
Subset Time Limit: 30000MS Memory Limit: 65536K Total Submissions: 5961 Accepted: 1129 Description G ...
- BFS例题:A计划
ContribContrib/a11y/accessibility-menu.js 关于 BFS要点: 1.若为可化为的坐标系图形,可用结构体存储其x值,y值和步数.(一般开now 和 next ,n ...
- Erlang OTP设计原则Gen_Fsm行为[转]
转自: http://www.cnblogs.com/yourihua/archive/2012/05/13/2497776.html 1. Fsm 称为 有限状态机,举个例子,游戏中的怪物称为NPC ...
- 【APUE】Chapter8 Process Control
这章的内容比较多.按照小节序号来组织笔记的结构:再结合函数的示例带代码标注出来需要注意的地方. 下面的内容只是个人看书时思考内容的总结,并不能代替看书(毕竟APUE是一本大多数人公认的UNIX圣经). ...
- selenium获取浏览器控制台日志
public void logsTest(){ WebDriver driver = null; try { System.setProperty("webdriver.chrome.dri ...
- 解决Navicat for MySQL 连接 Mysql 8.0.11 出现1251- Client does not support authentication protocol 错误
安装MySQL8.0之后,使用Navicat连接数据库,报1251错误. 上网搜索解决方案,网上说出现这种情况的原因是:mysql8 之前的版本中加密规则是mysql_native_password, ...
- IOS与Unity交互
学习了宣雨松的两篇Unity和IOS交互的文章,自己动手做了下,遇到了些问题,在此记录 先说IOS发送消息给Unity:(文章地址:http://www.xuanyusong.com/archives ...
- winform-实现类似QQ停靠桌面上边缘隐藏的效果
//实现类似QQ停靠桌面上边缘隐藏的效果! private void timer1_Tick(object sender, EventArgs e) { System.Drawing.Point pp ...
- Python全栈工程师(exercises)
# # 练习: # # 1. 用map函数求: # # 1**3 + 2**3 + 3 ** 3 + .... 9**3 的和 def add_(x): return x ** 3 print(sum ...