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\).问将数列清零至少需要 ...
随机推荐
- iOS 开发之 Xcode6 installation failed invalid argument!
1.运行模拟器的时候 报出: installation failed invalid argument! 原因分析: 我把Bundle indentifier 置为空了! http://stackov ...
- iOS开发之 Xcode 6 创建一个Empty Application
参考链接http://jingyan.baidu.com/article/2a138328bd73f2074b134f6d.html Xcode 6 正式版如何创建一个Empty Applicatio ...
- golang时间
//获取本地location toBeCharge := "2015-01-01 00:00:00" //待转化为时间戳的字符串 注意 这里的小时和分钟还要秒必须写 因为是跟着模板 ...
- Linux计划任务入门详解
Linux操作系统定时任务系统 Cron 入门 cron是一个linux下的定时执行工具,可以在无需人工干预的情况下运行作业.由于Cron 是Linux的内置服务,但它不自动起来,可以用以下的方法启动 ...
- SCCM日志存放路径
sccm有一些比较重要的日志大家可能经常需要查看.下面是一些比较常用的日志文件的存放位置. 客户端日志文件: 日志位于服务器端 SMS_CCM\Logs 文件夹中 日志位于客户端 %Windir%\S ...
- dede标签调用
关键描述调用标签: <meta name="keywords" content="{dede:field name='keywords'/}">&l ...
- 10款实用Android UI 开发框架
1. ActionBarSherlock ActionBarSherlock是一个独立的Android设计库,可以让Android 2.x的系统也能使用ActionBar.此外,ActionBarSh ...
- php 变量原理
1.php作为一种弱类型语言,不需要显式的指明变量的类型,但是php变量也是有类型的,php变量包含以下8种变量(三大类) a.标量类型:boolean,integer,float(double),s ...
- HTML5自学笔记[ 21 ]canvas绘图实例之马赛克
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- CentOS 6.x安装配置
简述 VMware可以创建多个虚拟机,每个虚拟机上都可以安装各种类型的操作系统.安装方法也有很多种.下面,主要以ISO镜像安装为例,介绍CentOS 6.x的安装过程及相关的参数设置. 简述 创建虚拟 ...