3342 绿色通道

 时间限制: 1 s
 空间限制: 256000 KB
 题目等级 : 黄金 Gold
 查看运行结果
 
 
题目描述 Description

《思远高考绿色通道》(Green Passage, GP)是唐山一中常用的练习册之一,其题量之大深受lsz等许多oiers的痛恨,其中又以数学绿色通道为最。2007年某月某日,soon-if (数学课代表),又一次宣布收这本作业,而lsz还一点也没有写……

高二数学《绿色通道》总共有n道题目要写(其实是抄),编号1..n,抄每道题所花时间不一样,抄第i题要花a[i]分钟。由于lsz还要准备NOIP,显然不能成天写绿色通道。lsz决定只用不超过t分钟时间抄这个,因此必然有空着的题。每道题要么不写,要么抄完,不能写一半。一段连续的空题称为一个空题段,它的长度就是所包含的题目数。这样应付自然会引起马老师的愤怒。马老师发怒的程度(简称发怒度)等于最长的空题段长度。

现在,lsz想知道他在这t分钟内写哪些题,才能够尽量降低马老师的发怒度。由于lsz很聪明,你只要告诉他发怒度的数值就可以了,不需输出方案。(快乐融化:那么lsz怎么不自己写程序?lsz:我还在抄别的科目的作业……)

输入描述 Input Description

第一行为两个整数n,t,代表共有n道题目,t分钟时间。

以下一行,为n个整数,依次为a[1], a[2],... a[n],意义如上所述。

输出描述 Output Description

仅一行,一个整数w,为最低的发怒度。

样例输入 Sample Input

17 11

6 4 5 2 5 3 4 5 2 3 4 5 2 3 6 3 5

样例输出 Sample Output

3

数据范围及提示 Data Size & Hint

60%数据 n<=2000

100%数据 0<n<=50000,0<a[i]<=3000,0<t<=100000000

思路:

  二分+线段树+DP;

  某犇说要用到单调队列;

  但是蒟蒻不会只能用线段树(单调队列200msac,线段树3200msac);

  二分大家都能想到,然后DP大家都能想到;

  但是DP时n^2的,所以我们要用线段树(单调队列)优化成n的;

  然后,轻松ac;

来,上代码:

  1. #include <cstdio>
  2. #include <iostream>
  3. #include <algorithm>
  4.  
  5. #define maxn 50005
  6.  
  7. using namespace std;
  8.  
  9. struct TreeNodeType {
  10. int l,r,dis,mid;
  11. };
  12. struct TreeNodeType tree[maxn<<];
  13.  
  14. int if_z,n,t,cost[maxn],ans;
  15.  
  16. char Cget;
  17.  
  18. inline void read_int(int &now)
  19. {
  20. now=,if_z=,Cget=getchar();
  21. while(Cget>''||Cget<'')
  22. {
  23. if(Cget=='-') if_z=-;
  24. Cget=getchar();
  25. }
  26. while(Cget>=''&&Cget<='')
  27. {
  28. now=now*+Cget-'';
  29. Cget=getchar();
  30. }
  31. now*=if_z;
  32. }
  33.  
  34. void tree_build(int now,int l,int r)
  35. {
  36. tree[now].l=l,tree[now].r=r;
  37. if(l==r) return ;
  38. tree[now].mid=(l+r)>>;
  39. tree_build(now<<,l,tree[now].mid);
  40. tree_build(now<<|,tree[now].mid+,r);
  41. }
  42.  
  43. inline void tree_up(int now)
  44. {
  45. tree[now].dis=min(tree[now<<].dis,tree[now<<|].dis);
  46. }
  47.  
  48. void tree_start(int now)
  49. {
  50. tree[now].dis=;
  51. if(tree[now].l==tree[now].r) return ;
  52. tree_start(now<<),tree_start(now<<|);
  53. }
  54.  
  55. void tree_change(int now,int to,int x)
  56. {
  57. if(tree[now].l==tree[now].r&&tree[now].l==to)
  58. {
  59. tree[now].dis=x;
  60. return ;
  61. }
  62. if(to<=tree[now].mid) tree_change(now<<,to,x);
  63. else tree_change(now<<|,to,x);
  64. tree_up(now);
  65. }
  66.  
  67. int tree_query(int now,int l,int r)
  68. {
  69. if(tree[now].l==l&&tree[now].r==r)
  70. {
  71. return tree[now].dis;
  72. }
  73. if(l>tree[now].mid) return tree_query(now<<|,l,r);
  74. else if(r<=tree[now].mid) return tree_query(now<<,l,r);
  75. else
  76. {
  77. return min(tree_query(now<<,l,tree[now].mid),tree_query(now<<|,tree[now].mid+,r));
  78. }
  79. }
  80.  
  81. void tree_check(int now)
  82. {
  83. if(tree[now].l==tree[now].r)
  84. {
  85. printf("%d ",tree[now].dis);
  86. return ;
  87. }
  88. tree_check(now<<);tree_check(now<<|);
  89. }
  90.  
  91. bool check(int size)
  92. {
  93. size++;
  94. tree_start();
  95. for(int i=;i<=n+;i++)
  96. tree_change(,i,tree_query(,max(,i-size),i-)+cost[i]);
  97. //tree_check(1);
  98. //printf("\n");
  99. int pos=tree_query(,n+,n+);
  100. if(pos<=t) return true;
  101. else return false;
  102. }
  103.  
  104. int main()
  105. {
  106. read_int(n),read_int(t);
  107. for(int i=;i<=n;i++) read_int(cost[i]);
  108. int lit=,rit=n,mid;
  109. ans=n;
  110. tree_build(,,n+);
  111. while(lit<=rit)
  112. {
  113. mid=(lit+rit)>>;
  114. if(check(mid))
  115. {
  116. rit=mid-;
  117. ans=mid;
  118. }
  119. else lit=mid+;
  120. }
  121. printf("%d\n",ans);
  122. return ;
  123. }

AC日记——绿色通道 codevs 3342的更多相关文章

  1. AC日记——楼房 codevs 2995

    2995 楼房  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 地平线(x轴)上有n个矩(lou ...

  2. AC日记——传话 codevs 1506 (tarjan求环)

    1506 传话  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 白银 Silver 题解       题目描述 Description 一个朋友网络,如果a认识b,那么如果a第 ...

  3. AC日记——蓬莱山辉夜 codevs 2830

    2830 蓬莱山辉夜  时间限制: 1 s  空间限制: 32000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 在幻想乡中,蓬莱山辉夜是月球 ...

  4. AC日记——苹果树 codevs 1228

    1228 苹果树  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 在卡卡的房子外面,有一棵 ...

  5. AC日记——刺激 codevs 1958

    时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold     题目描述 Description saffah的一个朋友S酷爱滑雪,并且追求刺激(exitement,由于刺激 ...

  6. AC日记——红与黑 codevs 2806

    2806 红与黑  时间限制: 1 s  空间限制: 64000 KB  题目等级 : 白银 Silver 题解  查看运行结果     题目描述 Description 有一个矩形房间,覆盖正方形瓷 ...

  7. AC日记——热浪 codevs 1557 (最短路模板题)

    1557 热浪  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 德克萨斯纯朴的民眾们这个夏 ...

  8. AC日记——字典 codevs 4189

    4189 字典  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 大师 Master 题解  查看运行结果     题目描述 Description 最经,skyzhong得到了 ...

  9. AC日记——开关灯 codevs 1690

    开关灯 思路: 线段树: bool懒标记维护: 更新区间时是区间总值减去当前值: 来,上代码: #include <cstdio> #include <cstring> #in ...

随机推荐

  1. Python + Bottle + 谷歌搜索Api 实现简单搜索引擎

    1.运行环境 python3 centos7 2.Bottle的使用 使用bottle主要是因为它仅用python自带的库即可实现对web的搭建. bottle源码分析 bottle使用教程 3.代码 ...

  2. [提供可行性脚本] RHEL 7/CentOS 7/Fedora28 重命名网卡名称

    实验说明: 在许多自动化任务中,脚本往往是通过读取配置文件来获取信息的,红帽系的系统自升级之后(CentOS7/RHEL7),网卡命名采用“一致性网络设备接口”的命名方法,导致不同设备的不同网卡名称各 ...

  3. centos7.4进入单用户模式

    centos7.4进入单用户模式 1 - 在启动grub菜单,选择编辑选项启动 2 - 按键盘e键,来进入编辑界面 3 - 找到Linux 16的那一行,将ro改为rw init=/sysroot/b ...

  4. 安装cfssl证书生成工具

    wget https://pkg.cfssl.org/R1.2/cfssl_linux-amd64 wget https://pkg.cfssl.org/R1.2/cfssljson_linux-am ...

  5. 【mysql】【windows】MySQL 服务无法启动,服务没有报告任何错误,请键入 NET HELPMSG 3534 以获得更多的帮助。

    成功安装以后,启动MySQL,输入: net start mysql 提示: ”MySQL 服务无法启动,服务没有报告任何错误,请键入 NET HELPMSG 3534 以获得更多的帮助.” 查了下, ...

  6. Goroutines和Channels

    原文链接 https://golangbot.com/goroutines/ Goroutines Goroutines 可以被认为是多个函数或方法同时允许.可以认为是一个轻量级的线程.与线程的花费相 ...

  7. poj-2488 a knight's journey(搜索题)

    Time limit1000 ms Memory limit65536 kB Background The knight is getting bored of seeing the same bla ...

  8. nmap命令扫描存活主机

    1.ping扫描:扫描192.168.0.0/24网段上有哪些主机是存活的:   [root@laolinux ~]# nmap -sP 192.168.0.0/24 Starting Nmap 4. ...

  9. Nginx从入门到放弃-第3章 场景实战篇

    3-1场景实践篇内容介绍: 3-2 Nginx作为静态资源Web服务_静态资源类型: 3-3 Nginx作为静态资源web服务_CDN(内容分发网络)场景: 3-4 Nginx作为静态资源Web服务_ ...

  10. dict的特性和基本语法——python3.6

    特性 key:value结构,字典中的每一个元素,都是键值对 key必须可被hash,且必须为不可变数据类型,必须唯一 可存放任意多个值,可修改,可以不唯一 无序 查找速度快,因为hash可以把key ...