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\).问将数列清零至少需要 ...
随机推荐
- (二)shell中case语句、程序传参、while
2.2.6.1.case语句(1)shell中的case语句和C语言中的switch case语句作用一样,格式有差异(2)shell中的case语句天生没有break,也不需要break,和C语言中 ...
- 如何查看与刷新DNS本地缓存
如何查看与刷新DNS本地缓存 一.查看DNS本地缓存 在cmd窗口输入:ipconfig/displaydns 二.刷新DNS本地缓存 在cmd窗口输入:ipconfig/flushdns 之后输入: ...
- 在Android中查看和管理sqlite数据库
在Android中可以使用Eclipse插件DDMS来查看,也可以使用Android工具包中的adb工具来查看.android项目中的sqlite数据库位于/data/data/项目包/databas ...
- C++——输入、输出和文件
一.C++输入和输出概述 1.1.流和缓冲区 C++程序把输入和输出看作字节流.输入时,程序从输入流中抽取字节:输出时,程序将字节插入到输出流中.对于面相文本的程序,每个字节代表一个字符,更通俗地说, ...
- 记录---base64
什么是Base64呢? Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下 ...
- css三级下拉的导航栏
#menu{ height: 65px; width:100%; background-color: rgba(0, 0, 0, 0.5);}#menu ul{ list-style: none;}# ...
- window2012 64bit 安装sqlserver2012 64bit调用excel的驱动安装
如果电脑已经安装了32bit的office那么可以使用 管理员权限打开cmd,然会执行以下命令 AccessDatabaseEngine_X64.exe /passive
- @ResponseStatus
返回一个指定的http response状态码. @ResponseStatus(value = HttpStatus.NOT_FOUND, reason = "IOException oc ...
- python 练习 29
Python Number 数据类型用于存储数值. 数据类型是不允许改变的,这就意味着如果改变 Number 数据类型的值,将重新分配内存空间. 以下实例在变量赋值时 Number 对象将被创建: v ...
- Java中print、printf、println
Java中的System.out输出会用到print.println以及printf命令. 其中 print一般的标准输出,但是不换行. println对比print即在结尾处多了换行. eg:pr ...