题目描述

给定n,k和一个长度为n的序列,求最长的最大值最小值相差不超过k的序列

输入格式

第一行两个有空格隔开的整数k(0<=k<=2000,000,000),n(1<=n<=3000,000),k代表设定的最大值,n代表序列的长度。第二行为n个由空格隔开的整数ai(1<=ai<=2000,000,000),表示序列。

输出格式

一个整数代表最大的符合条件的序列

首先解释一下题目:这道题让我们求出一个长度为n的序列中最长的一段子序列,满足这段子序列的最大值减最小值的差不超过k,求子序列的最大长度。
因为单调队列可以记录下一段区间的最大值和最小值,所以这道题我们完全可以用一个单调队列来实现。

我们设立一个l和r变量,分别表示子区间的左边界和右边界。接下来我们对任意一个子序列进行移动:
移动操作有两种情况,第一种即当该单调区间的最大值减去最小值的差小于等于k时,该单调区间是一个合法的区间。这时我们可以对答案进行记录,然后让r++,再进行判断是否会有更大的区间。

第二种情况,即当该单调区间的最大值减去最小值的差大于k时,该区间是一个不合法的区间。这时候我们不能将r++,因为这种操作不可能减小该区间内的最大值或增大该区间内的最小值,使变成一个合法的区间。我们只能将l++,然后注意要根据之前的a[l]和maxn,minn之间关系的三种情况对最大值和最小值进行维护。注意,单调队列是单调的,它只能往右移动,绝对不能出现往左移动的状况,即绝对不能l--或r--

这样我们就成功维护了单调队列的操作。

代码:

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int inf=0x3f3f3f3f;
4 int k,n,l,r,maxn,minn,ans;
5 int a[3000005];
6 void find(int l,int r){
7 maxn=-inf;minn=inf;
8 for(int i=l;i<=r;i++){
9 maxn=max(maxn,a[i]);
10 minn=min(minn,a[i]);
11 }
12 }
13 int main(){
14 cin>>k>>n;
15 for(int i=1;i<=n;i++){
16 cin>>a[i];
17 }
18 l=1;r=2;
19 maxn=max(a[1],a[2]);
20 minn=min(a[1],a[2]);
21 while(1){
22 if(maxn-minn>k){
23 if((a[l]==minn)||(a[l]==maxn)){
24 l++;
25 find(l,r);
26 }else if(a[l]>minn){
27 l++;
28 }
29 }else{
30 r++;
31 if(a[r]<minn){
32 minn=a[r];
33 }else if(a[r]>maxn){
34 maxn=a[r];
35 }
36 if(maxn-minn<=k){
37 ans=max(ans,r-l+1);
38 }
39 }
40 if(r==n){
41 break;
42 }
43 }
44 cout<<ans<<endl;
45 return 0;
46 }

P3512 [POI2010]PIL-Pilots 单调队列的应用的更多相关文章

  1. bzoj2096[Poi2010]Pilots 单调队列

    2096: [Poi2010]Pilots Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 983  Solved: 513[Submit][Statu ...

  2. BZOJ 2096: [Poi2010]Pilots 单调队列

    Code: #include<bits/stdc++.h> #define maxn 4000000 using namespace std; void setIO(string s) { ...

  3. BZOJ 2096 Pilots - 单调队列STL(deque)

    传送门 分析: 单调队列:维护两个递增.递减的队列,每次都加入新元素并更新,如果最大值(递减队首)-最小值(递增队首) > k,那么将最左段更新为前面两者中较前的那一个,并弹掉.用deque可以 ...

  4. 【BZOJ2096】[Poi2010]Pilots 双指针+单调队列

    [BZOJ2096][Poi2010]Pilots Description Tz又耍畸形了!!他要当飞行员,他拿到了一个飞行员测试难度序列,他设定了一个难度差的最大值,在序列中他想找到一个最长的子串, ...

  5. 【单调队列】bzoj2096 [Poi2010]Pilots

    用两个单调队列维护序列中的最大值和最小值即可. poi~ #include<cstdio> #include<algorithm> using namespace std; i ...

  6. bzoj2093: [Poi2010]Frog(单调队列,倍增)

    2093: [Poi2010]Frog Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 568  Solved: 186[Submit][Status] ...

  7. [POI2010]PIL-Pilots 单调队列

    [POI2010]PIL-Pilots 题意: 给定一个序列和一个数值k,求一段连续最大区间是的最大值与最小值之差小于k: 思路: 因为要维护最大值和最小值并且连续,使用两个单调队列分别同时维护最大最 ...

  8. bzoj1233 单调队列优化dp

    https://www.lydsy.com/JudgeOnline/problem.php?id=1233 数据结构优化dp的代码总是那么抽象 题意:奶牛们讨厌黑暗. 为了调整牛棚顶的电灯的亮度,Be ...

  9. POJ1821 单调队列//ST表 优化dp

    http://poj.org/problem?id=1821 当我们在考虑内层循环j以及决策k的时候,我们可以把外层变量i看作定值,以此来优化dp状态转移方程. 题意 有n个工人准备铺m个连续的墙,每 ...

  10. P3512 [POI2010]PIL-Pilots-洛谷luogu

    刚研究完单调队列和单调栈 于是就找题做了 发现了这道蓝题 以为很简单 就着手来写了 然而 并不是我想的那样 只是有一点点思路 无奈 还是看了题解 好吧题解是真的挺好的 ---------------- ...

随机推荐

  1. ubuntu 替换国内源,清华源

    参考 https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/ Ubuntu 的软件源配置文件是 /etc/apt/sources.list.将系统自带的该文 ...

  2. C++ primer笔记 -数组和指针

    如果数组没有显示的提供元素的初始值,则数组元素会像普通变量一样的初始化: 1.在函数体外的内置类型的数组,其元素均初始化为0 2.在函数体内的内置类型的数组,其元素无初始化 3.如果为类类型,则不管位 ...

  3. mathcurve.com

    https://mathcurve.com/surfaces.gb/surfaces.shtml

  4. centos7 安装jupyter

    1.基本包安装 yum update -y yum install python-pip -y yum install bzip2 -y yum groupinstall "Developm ...

  5. RNN,LSTM,BERT

    目录 RNN LSTM 计算公式 参数量计算 self-attention bert 论文 源码 问题 问题:bert中进行ner为什么没有使用crf:使用DL进行序列标注问题的时候CRF是必备嘛(t ...

  6. spring缓存创建

    /** * * <b>创建缓存</b> * <p> * 创建缓存,若已存在直接返回. * <p> * @param cacheName * @retur ...

  7. ORACLE备份脚本(4-RMAN1级增量备份)

    创建目录 mkdir  -p  /bak/level1 mkdir  -p  /bak/arch1 chown -R oracle:oinstall  /bak/ vi  rmanlevel1.sh ...

  8. windows检查

    # coding: UTF-8 import psutil import platform import re def get_cpu_used(upu_base, interval=1): perc ...

  9. python利用xlwings写入一行或一列Excel数据

    注意点:这里的sheet参数默认是已经存在的sheet表,如不存在该sheet,则使用add方法新增即可,示例: wb = xw.Book(r"C:\Users\Desktop\result ...

  10. 基于Java语言的编码问题了解

    基于Java语言的编码问题了解 以下仅为本人工作.学习过程中所接触到的内容,不足之处欢迎指出. 近两天使用maven的tomcat插件,以及使用非插件版的tomcat部署项目时遇到了乱码问题,在解决乱 ...