本来按照老师的要求,我学OI的第一份解题报告应是在寒假完成的关于数据结构的基础题,但由于身体原因当时未能完成,那么就在省选赛前临时写几篇吧……
题目描述

花匠栋栋种了一排花,每株花都有自己的高度。花儿越长越大,也越来越挤。栋栋决定把这排中的一部分花移走,将剩下的留在原地,使得剩下的花能有空间长大,同时,栋栋希望剩下的花排列得比较别致。

具体而言,栋栋的花的高度可以看成一列整数ℎ1, ℎ2, … , ℎn。设当一部分花被移走后,剩下的花的高度依次为g1, g2, … , gm,则栋栋希望下面两个条件中至少有一个满足:

条件 A:对于所有的1 ≤ i ≤ m/2,g2i > g2i−1,且g2i > g2i+1

条件 B:对于所有的1 ≤ i ≤ m/2,g2i < g2i−1,且g2i < g2i+1

注意上面两个条件在m = 1时同时满足,当m > 1时最多有一个能满足。

请问,栋栋最多能将多少株花留在原地。

输入
输入的第一行包含一个整数 ,表示开始时花的株数。
第二行包含 个整数,依次为ℎ1, ℎ2,… , ℎn,表示每株花的高度。
输出

输出一行,包含一个整数m,表示最多能留在原地的花的株数
样例
FlowerNOIP2013.in
5
5 3 2 1 2
FlowerNOIP2013.out
3
数据范围

对于 20%的数据,n ≤ 10;
对于 30%的数据,n ≤ 25;
对于 70%的数据,n ≤ 1000,0 ≤ h_i ≤ 1000;
对于 100%的数据,1 ≤ n ≤ 100,000,0 ≤ h_i ≤1,000,000,所有的h_i随机生成,所有随机数服从某区间内的均匀分布。

个人分析

明显的最优子结构性质,可以用动规来做。应该注意到存在30%的变态数据(1 ≤ n ≤ 100,000,0 ≤ h_i ≤1,000,000),因此想拿满分应当找到线性的算法(这种提示也可以?…………)。A、B两种情况不仅不会增加复杂性,反而消除了对n奇偶性的讨论。两种情况可以简化为一种锯齿状的数列,只需讨论i前保留的花高度与花i的高度h[i]的关系即可。
第i朵花的高度为h[i](1 <= i <= n),前i朵花“尾部为升序”的最长序列长度为S1[i],“尾部为降序”的最长序列长度为S2[i]。
则有状态转移方程:
    1. (h[i] > h[i-1]):S1[i] = max(S1[i-1], S2[i-1] + 1);S2[i] = S2[i-1];
    2. (h[i] == h[i-1]):S1[i] = S1[i-1];S2[i] = S2[i-1];
    3. (h[i] < h[i-1]):S1[i] = S1[i-1];S2[i] = max(S2[i-1], S1[i-1] + 1);

由此可以写出复杂度为O(n)的动态规划代码:

  1.  1 //<NOIP2013> 花匠
  2.  
  3.  2 #include <cstdio>
  4.  
  5.  3 using namespace std;
  6.  
  7.  4 int maxm(int a, int b)
  8.  
  9.  5 {
  10.  
  11.  6     if(>= b )return a ;
  12.  
  13.  7         else return b;
  14.  
  15.  8 }
  16.  
  17.  9 const int maxn = ;
  18.  
  19.  int h[maxn] = {};  //
  20.  
  21.  int n;
  22.  
  23.  int S1[maxn], S2[maxn] ;
  24.  
  25.  //(1尾部为升序,2尾部为降序)
  26.  
  27.  int main(void)
  28.  
  29.  {
  30.  
  31.      FILE *in = fopen ("FlowerNOIP2013.in","r");
  32.  
  33.      FILE *out = fopen ("FlowerNOIP2013.out" ,"w");
  34.  
  35.      fscanf(in, "%d", &n);
  36.  
  37.      int i;
  38.  
  39.      for(= ; i <= n; i++)
  40.  
  41.          fscanf(in, "%d", &h[i]);
  42.  
  43.      S1[] = S2[] = ;   //初始状态
  44.  
  45.      
  46.  
  47.      for(int i = ;<= n; i++)
  48.  
  49.      {
  50.  
  51.          if(h[i] > h[i-]) // case1
  52.  
  53.          {
  54.  
  55.              S1[i] = maxm(S1[i-], S2[i-]+ );
  56.  
  57.              S2[i] = S2[i-];
  58.  
  59.          }
  60.  
  61.          else if (h[i] == h[i-])// case2
  62.  
  63.          {
  64.  
  65.              S1[i] = S1[i-];
  66.  
  67.              S2[i] = S2[i-];
  68.  
  69.          }
  70.  
  71.          else    //case 3
  72.  
  73.          {
  74.  
  75.              S1[i] = S1[i-];
  76.  
  77.              S2[i] = maxm(S1[i-]+, S2[i-] );
  78.  
  79.          }
  80.  
  81.      }
  82.  
  83.      
  84.  
  85.      fprintf(out, "%d", maxm(S1[n], S2[n]) );
  86.  
  87.      return ;
  88.  
  89.  }

[NOIP2013 花匠] 新人解题报告的更多相关文章

  1. [NOIP2013]车站分级 解题报告

    妈蛋这道普及组水(神)题搞了我非常久. 一. 首先一个非常显然的事情就是每一个火车告诉了站与站之间的等级关系,所以拓扑求最长路. 可是发现暴力建边的话最坏能够达到500*500,所以时间复杂度有O(M ...

  2. 人生第一场CTF的解题报告(部分)

    解题报告 濮元杰部分: 王者归来: 120 场景 小王入职了一段时间,最近有点无聊.Web安全项目不多,白天看着其他项目组的同事忙得热火朝天,小王有点坐不住了,这也许是新人都会有的想法,乐于助人.想到 ...

  3. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  4. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  5. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  6. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  7. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  8. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  9. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

随机推荐

  1. 【Linux学习】nohup后台运行程序以及输出重定向

    Linux有两种命令使程序后台运行 第一种:支持后台运行,但是关闭终端的话,程序也会停止 command & 第二种:支持后台运行,关闭终端后,程序也会继续运行 nohup command & ...

  2. 海量数据排序——如果有1TB的数据需要排序,但只有32GB的内存如何排序处理?

    转载:https://blog.csdn.net/fx677588/article/details/72471357 1.外排序  传统的排序算法一般指内排序算法,针对的是数据可以一次全部载入内存中的 ...

  3. web.py输出中文字符串乱码问题的解决

    web.py中文字符串网页显示乱码的解决 #!/usr/bin/env python # encoding: utf-8 import weburls = ( '/', 'index')class i ...

  4. .build_release/lib/libcaffe.so: undefined reference to `cv::VideoCapture::set(int, double)'

    CXX/LD -o .build_release/tools/convert_imageset.bin.build_release/lib/libcaffe.so: undefined referen ...

  5. 阿里云ECS的使用

    一.阿里云ECS的使用 1.Linux CentOS Ubuntu Readhat 2.远程登录 xshell 远程登录 winScp 远程文件操作 3.Linux命令 cd 目录名 ls . ls ...

  6. [New learn]响应者链机制介绍

    1.简介  测试代码库:https://github.com/xufeng79x/EventHandler 响应者链是系统寻找事件相应者的一个路径,他是同touch事件的Hit-testing过程具有 ...

  7. Iptables基础整理

    Iptables基础框架

  8. java常用设计模式学习心得

    学习自:http://shenzhenchufa.blog.51cto.com/730213/161581 代码来自:http://shenzhenchufa.blog.51cto.com/73021 ...

  9. hdu 3081(二分+并查集+最大流||二分图匹配)

    Marriage Match II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  10. mysql数据库设置远程连接权限

    原文 问题现象 mysql 安装完毕,本机登录正常,在远程输入正确账号密码登录连接时报错如下 问题原因 远程IP没有登录权限,root用户默认只能在localhost也就是只能在本机登录,需要设置允许 ...