NOIP2013 提高组day2 2 花匠 动规 找拐点 树状数组
花匠
描述
花匠栋栋种了一排花,每株花都有自己的高度。花儿越长越大,也越来越挤。栋栋决定把这排中的一部分花移走,将剩下的留在原地,使得剩下的花能有空间长大,同时,栋栋希望剩下的花排列得比较别致。
具体而言,栋栋的花的高度可以看成一列整数h1, h2, … , hn。设当一部分花被移走后,剩下的花的高度依次为g1, g2, … , gm,则栋栋希望下面两个条件中至少有一个满足:
条件 A:对于所有的1<i<m/21<i<m/2,g2i>g2i−1g2i>g2i−1,且g2i>g2i+1g2i>g2i+1;
条件 B:对于所有的1<i<m/21<i<m/2,g2i<g2i−1g2i<g2i−1,且g2i<g2i+1g2i<g2i+1。
注意上面两个条件在m = 1时同时满足,当m > 1时最多有一个能满足。
请问,栋栋最多能将多少株花留在原地。
格式
输入格式
输入的第一行包含一个整数 n,表示开始时花的株数。
第二行包含 n 个整数,依次为h1, h2,… , hn,表示每株花的高度。
输出格式
输出一行,包含一个整数 m,表示最多能留在原地的花的株数。
限制
每个测试点1s。
提示
对于 20%的数据,n ≤ 10;
对于 30%的数据,n ≤ 25;
对于 70%的数据,n ≤ 1000,0 ≤ hi ≤ 1000;
对于 100%的数据,1 ≤ n ≤ 100,000,0 ≤ hi ≤ 1,000,000,所有的h_i随机生成,所有随机数服从某区间内的均匀分布。
解题报告
啊,伤心的我这道题先开始只拿了10分。。。。明明很简单的,我想复杂了。。。。
虽然上面标题写了三种方法,其实我只写了一种
找拐点。跑两遍一个找+-+-+-+-+ 一个找 -+-+-+-(+:高,-低)
代码如下:
#include<iostream>
#include<cstdio>
using namespace std;
int n,ans1=,ans2=,ans;
int a[];
int main()
{
freopen("flower.in","r",stdin);
freopen("flower.out","w",stdout);
cin>>n;
for (int i=;i<=n;i++)
scanf("%d",&a[i]);
int k=;
for(int i=;i<=n;i++)//-+-+-+-+-
{
if (a[i]>a[i-]&&k||a[i]<a[i-]&&!k)
{
ans1++;
k=!k;
}
}
k=;
for(int i=;i<=n;i++)//+-+-+-+-
{
if (a[i]>a[i-]&&k||a[i]<a[i-]&&!k)
{
ans2++;
k=!k;
}
}
if (ans1>ans2) ans=ans1;
else ans=ans2;
cout<<ans;
return ;
}
然后就完了,恩,等有空的时候编动规和树状数组
未完待续。。
这里有一份学长的树状数组版本:
#include <cstdio>//by xxx(姓名权保护)
#include <iostream>
#define Lowbit(x) ((x)&(-(x)))
using namespace std;
int n;
int h[], t0[], t1[], maxh;
int dp[][];
int getmax0( int x ) { // h]
int mval=;
while( x!= ) {
mval = max(mval,t0[x]);
x -= Lowbit(x);
}
return mval;
}
void update0( int x, int val ) {
while( x<=maxh ) {
t0[x] = max( t0[x], val );
x += Lowbit(x);
}
}
int getmax1( int x ) { // h]
int mval=;
while( x!= ) {
mval = max(mval,t1[x]);
x -= Lowbit(x);
}
return mval;
}
void update1( int x, int val ) {
while( x<=maxh ) {
t1[x] = max( t1[x], val );
x += Lowbit(x);
}
}
int main() {
freopen( "flower.in", "r", stdin );
freopen( "flower.out", "w", stdout );
scanf( "%d", &n );
for( int i=; i<=n; i++ ) {
scanf( "%d", h+i );
h[i]++;
maxh = max(maxh,h[i]);
dp[i][] = dp[i][] = ;
}
maxh++;
for( int i=; i<=n; i++ ) {
dp[i][] = getmax0(h[i]-)+;
dp[i][] = getmax1(maxh-h[i]-)+;
update0( h[i], dp[i][] );
update1( maxh-h[i], dp[i][] );
}
int ans=;
for( int i=; i<=n; i++ )
ans = max( ans, max(dp[i][],dp[i][]) );
printf( "%d\n", ans );
}
抽空一定要看。。
NOIP2013 提高组day2 2 花匠 动规 找拐点 树状数组的更多相关文章
- NOIP2013 提高组 Day2
期望得分:100+100+30+=230+ 实际得分:100+70+30=200 T2 觉得题目描述有歧义: 若存在2i却不存在2i+1,自己按不合法做的,实际是合法的 T3 bfs 难以估分 虽然 ...
- 积木大赛 noip2013提高组day2
这道题一开始想到处理中间是0的位置,但这样时间太慢了,后来想到一种类似二分的方法,就是把这一段的最小值找到,全部减去最小值,然后有0一出现,就又递归处理前一段,每次答案就加上这一段的最小值: AC代码 ...
- NOIP2013 提高组day2 3 华容道 BFS
描述 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面,华容道是否根本就无法完成,如果能完成,最少需要多少时间. 小 B 玩的华容道与经典的 ...
- 3537. 【NOIP2013提高组day2】华容道(搜索 + 剪枝)
Problem 给出一个类似华容道的图.\(q\)次询问,每次给你起始点,终止点,空格位置,让你求最少步数 \(n,m\le 30, q\le 500\). Soultion 一道智障搜索题. 弱智想 ...
- Noip2013 提高组 Day2 T1 积木大赛
题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...
- 【华容道】题解(NOIP2013提高组day2)
分析 这道题很容易想到令f[x][y][x1][y1]表示空白块在(x,y).指定棋子在(x1,y1)时的最少步数,让空白块和四周的棋子交换,当空白块要和指定棋子交换时,把指定棋子移动,搞一下BFS就 ...
- Day2:T4求逆序对(树状数组+归并排序)
T4: 求逆序对 A[I]为前缀和 推导 (A[J]-A[I])/(J-I)>=M A[j]-A[I]>=M(J-I) A[J]-M*J>=A[I]-M*I 设B[]=A[]-M*( ...
- [NOIP2013 提高组] 华容道 P1979 洛谷
[NOIP2013 提高组] 华容道 P1979 洛谷 强烈推荐,更好的阅读体验 经典题目:spfa+bfs+转化 题目大意: 给出一个01网格图,和点坐标x,y空格坐标a,b,目标位置tx,ty要求 ...
- [NOIp2013提高组]积木大赛/[NOIp2018提高组]铺设道路
[NOIp2013提高组]积木大赛/[NOIp2018提高组]铺设道路 题目大意: 对于长度为\(n(n\le10^5)\)的非负数列\(A\),每次可以选取一个区间\(-1\).问将数列清零至少需要 ...
随机推荐
- numpy库的常用知识
为什么有numpy这个库呢?准安装的Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列表的元素可以是任何对象,因此列表中所保存的是对象的指针.这样为了保存一个简单的[1,2, ...
- arr.sort()排序方法
<!DOCTYPE html><html lang="zh-CN"><head> <meta charset="UTF-8&qu ...
- c++ 对象内存分配和虚函数
1. c++类对象(不含虚函数)在内存中的分布 c++类中有四种成员:静态数据.非静态数据.静态函数.非静态函数. 1. 非静态数据成员放在每个对象内部,作为对象专有的数据成员 2. 静态数据成员被抽 ...
- 使用TCP/IP的套接字(Socket)进行通信
http://www.cnblogs.com/mengdd/archive/2013/03/10/2952616.html 使用TCP/IP的套接字(Socket)进行通信 套接字Socket的引入 ...
- C#程序以管理员权限运行【我采用了第二种,比较好用】
在Vista 和 Windows 7 及更新版本的操作系统,增加了 UAC(用户账户控制) 的安全机制,如果 UAC 被打开,用户即使以管理员权限登录,其应用程序默认情况下也无法对系统目录.系统注册表 ...
- jQuery笔记一
陆续更新中..... 1,创建标签的时候可以提前写好,以后用clone()方法克隆即可. 如: var div=$("<div></div>"); var ...
- 25套用于Web UI设计的免费PSD网页元素模板
Web 元素是任何网站相关项目都需要的,质量和良好设计的元素对于设计师来说就像宝贝一样.如果您正在为您的网站,博客,Web 应用程序或移动应用程序寻找完美设计的网页元素,那么下面这个列表会是你需要的. ...
- VBA对象模型(2)
Excel对象模型简介 在介绍Excel对象模型之前,让我们先来看一个简单的例子.大多数工厂都是按这样的结构进行设置的:最上层为工厂总部,第二层次分为各个车间,在车间下面又分各班组.就这样组织在一起, ...
- [svn] 分支开发
参考博客: http://www.cnblogs.com/cxd4321/archive/2012/07/12/2588110.html (1)为什么要使用SVN分支开发和主干合并? 目的:在SVN下 ...
- Core Data系列文章(一)Core Data基础
在iOS开发数据库SQLite的使用介绍了iOS中使用SQLite对数据进行持久化存储,实际上是对数据库直接进行操作,而苹果专门有一套API来间接的对数据进行持久化存储,而且主要针对用户创建的对象 - ...