beautiful

2.1 题目描述

一个长度为 n 的序列,对于每个位置 i 的数 ai 都有一个优美值,其定义是:找到序列中最 长的一段 [l, r],满足 l ≤ i ≤ r,且 [l, r] 中位数为 ai(我们比较序列中两个位置的数的大小时, 以数值为第一关键字,下标为第二关键字比较。这样的话 [l, r] 的长度只有可能是奇数),r - l + 1 就是 i 的优美值。 接下来有 Q 个询问,每个询问 [l, r] 表示查询区间 [l, r] 内优美值的最大值。
2.2 输入

第一行输入 n 接下来 n 个整数,代表 ai 接下来 Q,代表有 Q 个区间接下来 Q 行,每行 两个整数 l, r(l ≤ r),表示区间的左右端点

2.3 输出
对于每个区间的询问,输出答案
2.4 Sample Input

8

16 19 7 8 9 11 20 16

8

3 8

1 4

2 3

1 1

5 5

1 2

2 8

7 8
2.5 Sample Output

7

3

1

3

5

3

7

3
3
2.6 数据范围及约定

对于 30% 的数据,满足 n,Q ≤ 50

对于 70% 的数据,满足 n,Q ≤ 2000 对于所有数据,满足 n ≤ 2000, Q ≤ 100000,ai ≤ 200

———————————————分割线———————————————

考试没有理解这道题,导致连暴力都没有写出来,本题直接爆零。

看完标程和解题报告后豁然开朗。

n2 预处理。对于每个数,往左往右各扫一遍,遇到大于它的数则状态 S++,小于则 S--, 由题目定义可知没有相等的。然后记录下每个状态 S 的最长长度,然后枚举左边的状态,找右边的状态,取 max 计算出优美值。 接着就是一个纯 RMQ 的问题了.

  1. #include "cstdio"
  2. #include "cstring"
  3. #include "iostream"
  4.  
  5. using namespace std ;
  6. const int maxN = ;
  7. const int INF = ;
  8. typedef long long QAQ ;
  9.  
  10. int L[ maxN ] , R[ maxN ] , w[ maxN ] , A[ maxN ] ;
  11.  
  12. inline int max ( int x , int y ) { return x < y ? y : x ;}
  13.  
  14. void Init ( int n ) {
  15. for ( int i= ; i<=n ; ++i ) {
  16. memset ( L , , sizeof ( L ) ) ;
  17. memset ( R , , sizeof ( R ) ) ;
  18. L[ n ] = ; R[ n ] = ;
  19. int _cnt = ;
  20.  
  21. for ( int j = i - ; j>= ; --j ) {
  22. if ( A[ j ] > A[ i ] ) ++_cnt ;
  23. else if ( A[ j ] <= A[ i ] ) --_cnt ;
  24. L[ n + _cnt ] = i - j ;
  25. }
  26.  
  27. _cnt = ;
  28. for ( int j = i + ; j <= n ; ++j ) {
  29. if ( A[ j ] >= A[ i ] ) ++_cnt ;
  30. else if ( A[ j ] < A[ i ] ) --_cnt ;
  31. R[ n + _cnt ] = j - i ;
  32. }
  33.  
  34. for ( int j = - i ; j <= i - ; ++j ) {
  35. if ( L[ n + j ] >= && R[ n - j ] >= ) {
  36. w [ i ] = max ( w [ i ] , L[ n + j ] + R[ n - j ] + ) ;
  37. }
  38. }
  39. }
  40. }
  41. int main ( ) {
  42. int N , T , l , r ;
  43. scanf ( "%d" , &N ) ;
  44. for ( int i= ; i<=N ; ++i ) {
  45. scanf ( "%d" , A + i ) ;
  46. }
  47. Init ( N ) ;
  48. scanf ( "%d" , &T ) ;
  49. while ( T-- ) {
  50. QAQ ans = -INF ;
  51. cin >> l >> r ;
  52. for ( int i=l ; i<=r ; ++i ) ans = max ( ans , w[ i ] ) ;
  53. printf ( "%I64d\n" , ans ) ;
  54. }
  55. }

Beauitiful

NOIP_RP++;

2016-10-08 00:18:20

(完)

20161005 NOIP 模拟赛 T2 解题报告的更多相关文章

  1. 20161003 NOIP 模拟赛 T2 解题报告

    Weed duyege的电脑上面已经长草了,经过辨认上面有金坷垃的痕迹. 为了查出真相,duyege 准备修好电脑之后再进行一次金坷垃的模拟实验. 电脑上面有若干层金坷垃,每次只能在上面撒上一层高度为 ...

  2. 20161005 NOIP 模拟赛 T3 解题报告

    subset 3.1 题目描述 一开始你有一个空集,集合可以出现重复元素,然后有 Q 个操作 1. add s 在集合中加入数字 s. 2. del s 在集合中删除数字 s.保证 s 存在 3. c ...

  3. 20161023 NOIP 模拟赛 T2 解题报告

    Task 2.回文串计数 (calc.pas/calc.c/calc.cpp) [题目描述] 虽然是一名理科生,Mcx常常声称自己是一名真正的文科生.不知为何,他对于背诵总有一种莫名的热爱,这也促使他 ...

  4. 【HHHOJ】NOIP模拟赛 玖 解题报告

    点此进入比赛 得分: \(100+20+100=220\)(还不错) 排名: \(Rank\ 16\) \(Rating\):\(+20\) \(T1\):[HHHOJ263]「NOIP模拟赛 玖」三 ...

  5. 【HHHOJ】NOIP模拟赛 捌 解题报告

    点此进入比赛 得分: \(30+30+70=130\)(弱爆了) 排名: \(Rank\ 22\) \(Rating\):\(-31\) \(T1\):[HHHOJ260]「NOIP模拟赛 捌」Dig ...

  6. NOIP欢乐模拟赛 T2 解题报告

    小澳的坐标系 (coordinate.cpp/c/pas) [题目描述] 小澳者表也,数学者景也,表动则景随矣. 小澳不喜欢数学,可数学却待小澳如初恋,小澳睡觉的时候也不放过. 小澳的梦境中出现了一个 ...

  7. CH Round #55 - Streaming #6 (NOIP模拟赛day2)解题报告

    T1九九归一 描述 萌蛋在练习模n意义下的乘法时发现,总有一些数,在自乘若干次以后,会变成1.例如n=7,那么5×5 mod 7=4,4×5 mod 7=6,6×5 mod 7=2,2×5 mod 7 ...

  8. CH Round #54 - Streaming #5 (NOIP模拟赛Day1)解题报告

    最近参加了很多CH上的比赛呢~Rating--了..题目各种跪烂.各种膜拜大神OTZZZ T1珠 描述 萌蛋有n颗珠子,每一颗珠子都写有一个数字.萌蛋把它们用线串成了环.我们称一个数字串是有趣的,当且 ...

  9. 20161007 NOIP 模拟赛 T1 解题报告

    排序 3.1 题意描述 众所周知,熟练掌握至少一种排序算法是参加NOIP的必备技能.常见的排序算法有冒泡 排序.归并排序.快速排序.奇偶排序.猴子排序.梳排序.鸡尾酒排序.臭皮匠排序等. 在这里,介绍 ...

随机推荐

  1. SQLServer子查询

    in谓词子查询 select * from dbo.Worker where did in (select dID from DepartMent) 比较运算子查询 select * from Wor ...

  2. 回溯法解决N皇后问题(以四皇后为例)

    以4皇后为例,其他的N皇后问题以此类推.所谓4皇后问题就是求解如何在4×4的棋盘上无冲突的摆放4个皇后棋子.在国际象棋中,皇后的移动方式为横竖交叉的,因此在任意一个皇后所在位置的水平.竖直.以及45度 ...

  3. 【JAVA常用类演示】

     一.java.lang.System类. public final class Systemextends Object 该类包含一些有用的类字段和方法.它不能被实例化. 在 System 类提供的 ...

  4. android 入门-R文件的死与活

    1.图片的名字Btn_Play R文件死了. 1.答:修改图片的名字btn_play R文件活了.

  5. PHPCMS_v9 wap不同列表采用不同模板的方法

    .在phpcms\modules\wap\index.php中搜索 $template = ($TYPE[$typeid]['parentid']==0 && in_array($ty ...

  6. PHP获取用户真实IP

    function get_client_ip() { if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP' ...

  7. 1:A+B Problem

    总时间限制:  1000ms  内存限制:  65536kB 描述 Calculate a + b 输入 Two integer a,,b (0 ≤ a,b ≤ 10) 输出 Output a + b ...

  8. Arduino101学习笔记(二)—— 一些注意的语法点

    1.宏定义 2.整数常量 3.支持C++ String类 (1)String 方法 charAt() compareTo() concat() endsWith() equals() equalsIg ...

  9. 数字信号处理实验(五)——IIR滤波器的设计

    一.使用自编函数设计IIR滤波器 1.冲激响应法 (1)注给出的数字滤波器指标先化成模拟指标 (2)设计出模拟滤波器: (3)使用冲激响应法转化成数字滤波器 (4)一个demo clear all; ...

  10. 学习linux内核时常碰到的汇编指令(2)

    转载:http://blog.sina.com.cn/s/blog_4be6adec01007xvh.html JNGE∶指令助记符——(有符号数比较)不大于且不等于转移(等价于JL).当SF和OF异 ...