Subsequence HDU - 3530
方法:单调队列区间最大最小
错误记录(本地写错)的原因:写成每次试着扩展右端点,却难以正确地处理"在多扩展右端点之后减去多扩展的部分"这一任务(分类太多,例如:由于无法扩展有端点有可能是因为有端点已经到达最右端,也可能是因为最大最小差超过要求)。显然那样写没有每次扩展一个右端点,并从左侧开始删直到重新使序列符合标准(two_pointers?)方便。
#include<cstdio>
#include<algorithm>
using namespace std;
int a[],qmin[],qmax[],n,m,k,lmin,rmin,lmax,rmax,l,r,maxans;
int main()
{
int i;
while(scanf("%d%d%d",&n,&m,&k)==)
{
lmin=rmin=lmax=rmax=maxans=;l=;
for(i=;i<=n;i++)
scanf("%d",&a[i]);
for(r=;r<=n;r++)
{
while(lmin<rmin&&a[qmin[rmin-]]>=a[r]) --rmin;
qmin[rmin++]=r;
while(lmax<rmax&&a[qmax[rmax-]]<=a[r]) --rmax;
qmax[rmax++]=r;
while(l<=r&&(a[qmax[lmax]]-a[qmin[lmin]]>k))
{
if(lmin<rmin&&qmin[lmin]<=l) lmin++;
if(lmax<rmax&&qmax[lmax]<=l) lmax++;
l++;
}
if(l<=r&&a[qmax[lmax]]-a[qmin[lmin]]>=m)
maxans=max(maxans,r-l+);
}
printf("%d\n",maxans);
}
return ;
}
Subsequence HDU - 3530的更多相关文章
- hdu 3530 单调队列最值
		/** HDU 3530 单调队列的应用 题意: 给定一段序列,求出最长的一段子序列使得该子序列中最大最小只差x满足m<=x<=k. 解题思路: 建立两个单调队列分别递增和递减维护(头尾删 ... 
- hdu 3530 Subsequence
		题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=3530 Subsequence Description There is a sequence of i ... 
- 【单调队列+尺取】HDU 3530 Subsequence
		acm.hdu.edu.cn/showproblem.php?pid=3530 [题意] 给定一个长度为n的序列,问这个序列满足最大值和最小值的差在[m,k]的范围内的最长子区间是多长? [思路] 对 ... 
- HDU 3530 Subsequence(单调队列)
		传送门 Description There is a sequence of integers. Your task is to find the longest subsequence that s ... 
- HDU - 3530 Subsequence (单调队列)
		Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ... 
- hdu 3530 Subsequence 单调队列
		题目链接 题目给出n个数, 一个下界m, 一个上界k, 让你求出最长的一段序列, 满足这段序列中的最大的数-最小的数<=k&&>=m, 输出这段长度. 可以维护两个队列, ... 
- hdu 3530 "Subsequence" (单调队列)
		传送门 题意: 给出一个序列,求最长的连续子序列,使得 m ≤ Max-Min ≤ k 我的理解: 定义数组 a[] 存储输入的 n 个数: 定义两个双端队列: deque<int >qM ... 
- Subsequence(hdu 3530)
		题意:给你一个长度为n的数列,要求一个子区间,使得区间的最大值与最小值的差s满足,m<=s<=k,求满足条件的最长子区间 /* 单调队列 我们可以用单调队列分别维护最大值和最小值 当差值大 ... 
- HDU 3530  单调队列
		题目大意:给你n个数, 让你问你最长的满足要求的区间有多长,区间要求:MAX - MIN >= m && MAX - MIN <= k 思路:单调队列维护递增和递减,在加入 ... 
随机推荐
- openssl 再爆惊天漏洞及紧急修复指南
			openssl 又摊上大事了,2014年6月5日,SSL/TLS Man-in-the-Middle Vulnerability 该漏洞使得攻击者能够拦截恶意中间节点加密和解密数据.同一时候强迫使用弱 ... 
- 手把手编写自己的PHPMVC框架
			1 什么是MVC MVC模式(Model-View-Controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器(Controller ... 
- 图像处理之 opencv 学习---矩阵的操作
			OpenCV的一些操作,如生成随机矩阵,高斯矩阵,矩阵相乘之类的 /*功能:说明矩阵的一些操作方法*/#include "cv.h"//该头文件包含了#include " ... 
- Mysql性能优化笔记
			一,索引 1.Innodb索引使用的是B+树 2.尽量简化where条件,比如不要出现 where id + 3 = 5,这无法使用索引 3.索引很大时,可以冗余一列来模拟哈希索引 4.小的表不需要使 ... 
- 常用SQL备忘录
			联表删除: delete t1,t2 from table_name t1 left join t2 on t1.id=t2.id where t1.id=23 (ps:该语句在mysql 5.0之前 ... 
- 使用jsoncpp解析生成json
			在此站点下载jsoncpp(https://sourceforge.net/projects/jsoncpp/这个站点的版本较旧) 在电脑上安装Python,运行amalgamate.py,生成的di ... 
- tomcat 部署项目的多种方式
			项目放在tomcat webapps也不会加载两次 下面可以指定项目名称及path 加载war 部署war包 后面不用加war的后缀 <Host appBase="D:/pr ... 
- Ruby map、each、select、inject、collect 、detect reference
			参考 https://ruby-china.org/topics/26718 map:(collect是map的别名函数) 对数组中每个元素进行表达式操作,原始数组不会被改变,返回执行表达式结果的新数 ... 
- Kafka使用kclient三种使用方法
			kclient提供了三种使用方法,对于每一种方法,按照下面的步骤可快速构建Kafka生产者和消费者程序. 前置步骤1) 下载源代码后在项目根目录执行如下命令安装打包文件到你的Maven本地库. mvn ... 
- linux内核的三种主要调度策略
			linux内核的三种主要调度策略: 1,SCHED_OTHER 分时调度策略, 2,SCHED_FIFO实时调度策略,先到先服务 3,SCHED_RR实时调度策略,时间片轮转 实时进程将得到优先调用, ... 
