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\).问将数列清零至少需要 ...
随机推荐
- java中compareTo和compare方法之比较
这两个方法经常搞混淆,现对其进行总结以加深记忆. compareTo(Object o)方法是java.lang.Comparable接口中的方法,当需要对某个类的对象进行排序时,该类需要实现Comp ...
- Java 13 字符串
1 String对象不可变 每一个修改String值的方法 实际上都是创建一个全新的String对象 public class Immutable { public static String upc ...
- hdu 5476 Explore Track of Point(2015上海网络赛)
题目链接:hdu 5476 今天和队友们搞出3道水题后就一直卡在这儿了,唉,真惨啊……看着被一名一名地挤出晋级名次,确实很不好受,这道恶心的几何题被我们3个搞了3.4个小时,我想到一半时发现样例输出是 ...
- 【服务器环境搭建-Centos】常用系统命令篇
uname -a 查看系统信息
- hiho_1058_combination_lock
题目大意 给定N个字符,范围为A-Z,编号为1-N,对该字符序列进行M个操作,操作有4中类型: (1)CMD 1 i j X 将[i, j]区间内的字符均变为X (2)CMD 2 i j K ...
- iOS 轻量级的数据库leveldb
轻量级的数据库leveldb https://github.com/google/leveldb 一:在iOS下编译leveldb 终端: 1: git clone https://github.co ...
- Tiny语法分析器(递归下降分析法实现)
递归规约规则是这样的 program→stmt-sequence stmt-sequence→stmt-sequence;statement|statement statement→if-stmt|r ...
- Spring Boot 环境变量读取 和 属性对象的绑定
网上看到的一些方法,结合我看到的 和我们现在使用的.整理成此文: 第一种方法 参见catoop的博客之 Spring Boot 环境变量读取 和 属性对象的绑定(尊重原创) 第二种方法 class不用 ...
- 学习HTML5之新特性标签一览(详细)
HTML5又2008年诞生,HTML5大致可以等同于=html+css3+javascriptapi.... so --->支持css3强大的选择器和动画以及javascript的新的函数 先来 ...
- 初学java之接口基础
/* 长城牌电视机 联想奔月5008PC机 */ package st; //接口回调实例 interface ShowMessage { void 显示商标 (String s); } class ...