$Luogu$

$Sol$

$Poj1037\ A\ Decorative\ Fence$好像吖.

$f[i][0/1]$表示前$i$个数,且选了第$i$个数,这个数相对于上一个数是下降(上升)的,这样的序列的最大长度.

$f[i][0]=max(f[k][1])+1,k<i且h[k]>h[i]$

$f[i][1]=max(f[k][0])+1,k<i且h[k]>h[i]$

最后答案就是$max_{i=1}^{n}f[i][0/1]$.

然而这样的复杂度是$O(N^2/2)$的,不能$AC$,优化很容易想到能不能去掉内层循环,通过某个变量维护或者是$f[i][0/1]$直接由$f[i-1][0/1]$推出.前者似乎是不可行的,考虑后者.将$f[i][0]$的意思改成前$i$个数选了若干数,最后一个数相对于倒数第二个数是递减的序列的最长长度,$f[i][1]$类似.然而我根本就想不到转移方程于是打开$TJ....ovo$

$if(h[i]>h[i-1])f[i][1]=f[i-1][0]+1;else f[i][1]=f[i-1][1];$

$if(h[i]<h[i-1])f[i][0]=f[i-1][1]+1;else f[i][0]=f[i-1][0];$

最后答案是$f[n][0/1].$

这样理解叭,对于当前序列,假如最后一个数是波谷,那么我们是希望这个数越小越好的,因为后面的波峰更有选择余地.

$upd\ on\ 10.27:$发现我还是不会这题所以又回来看$TJ$,发现不是特别懂上面的$dp$做法,觉得正确性可能还是有点难理解,所以换了一种贪心做法,具体过程写在这里了,点目录里的$2013$可以快速跳转.

$Code$

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<algorithm>
#define il inline
#define Rg register
#define go(i,a,b) for(Rg int i=a;i<=b;++i)
#define yes(i,a,b) for(Rg int i=a;i>=b;--i)
#define mem(a,b) memset(a,b,sizeof(a))
#define ll long long
#define db double
#define inf 2147483647
using namespace std;
il int read()
{
Rg int x=0,y=1;char c=getchar();
while(c<'0'||c>'9'){if(c=='-')y=-1;c=getchar();}
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+c-'0';c=getchar();}
return x*y;
}
const int N=100010;
int n,h[N];
ll f[N][2];
il ll Max(ll x,ll y){return x>y?x:y;}
int main()
{
n=read();go(i,1,n)h[i]=read();
f[1][0]=f[1][1]=1;
go(i,2,n)
{
if(h[i]>h[i-1])f[i][1]=f[i-1][0]+1;
else f[i][1]=f[i-1][1];
if(h[i]<h[i-1])f[i][0]=f[i-1][1]+1;
else f[i][0]=f[i-1][0];
}
printf("%lld\n",max(f[n][0],f[n][1]));
return 0;
}

最新文章

  1. Unity 官网教程 -- Multiplayer Networking
  2. Shortcut 常用快捷键
  3. ubuntu12.04 gdb安装使用
  4. 什么php?
  5. 一期结业KTV项目难点
  6. 项目中ApplicationContext
  7. 一起来学linux:shell script(一)关于变量
  8. unicode、utf8、字符串字面值
  9. node.js 调试问题
  10. angular2版本迭代之特性追踪
  11. Iviews视频搜索引擎
  12. Oracle查看表空间容量
  13. SIP/2.0 403 Forbidden(Invalid domain in From: header)
  14. struts2之Action获取请求参数与web元素
  15. 如何免费上传4G以上大文件至百度云网盘
  16. Github开源项目分享
  17. canvas的一些问题记录
  18. JZOJ 5280 膜法师
  19. bzoj 2458: [BeiJing2011]最小三角形 题解
  20. 工厂模式 jdbc 面向接口dao 开发 单例

热门文章

  1. JQuery---高级选择器
  2. 在 Linux 安装 IIS?
  3. oracle 用表连接替换EXISTS
  4. 给radio添加点击事件
  5. Clipboard 自动复制功能,ios复制失败,换方案 user-select: text ;长按复制 (ios 兼容,长按复制)
  6. springboot 实现 aop
  7. Python--day47--mysql执行计划
  8. Python--day30--网络基础
  9. tensorflow op tf.global_variables_initializer
  10. vue 打包后,页面空白及图片路径的问题