P3512 [POI2010]PIL-Pilots 单调队列的应用
题目描述
给定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 单调队列的应用的更多相关文章
- bzoj2096[Poi2010]Pilots 单调队列
2096: [Poi2010]Pilots Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 983 Solved: 513[Submit][Statu ...
- BZOJ 2096: [Poi2010]Pilots 单调队列
Code: #include<bits/stdc++.h> #define maxn 4000000 using namespace std; void setIO(string s) { ...
- BZOJ 2096 Pilots - 单调队列STL(deque)
传送门 分析: 单调队列:维护两个递增.递减的队列,每次都加入新元素并更新,如果最大值(递减队首)-最小值(递增队首) > k,那么将最左段更新为前面两者中较前的那一个,并弹掉.用deque可以 ...
- 【BZOJ2096】[Poi2010]Pilots 双指针+单调队列
[BZOJ2096][Poi2010]Pilots Description Tz又耍畸形了!!他要当飞行员,他拿到了一个飞行员测试难度序列,他设定了一个难度差的最大值,在序列中他想找到一个最长的子串, ...
- 【单调队列】bzoj2096 [Poi2010]Pilots
用两个单调队列维护序列中的最大值和最小值即可. poi~ #include<cstdio> #include<algorithm> using namespace std; i ...
- bzoj2093: [Poi2010]Frog(单调队列,倍增)
2093: [Poi2010]Frog Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 568 Solved: 186[Submit][Status] ...
- [POI2010]PIL-Pilots 单调队列
[POI2010]PIL-Pilots 题意: 给定一个序列和一个数值k,求一段连续最大区间是的最大值与最小值之差小于k: 思路: 因为要维护最大值和最小值并且连续,使用两个单调队列分别同时维护最大最 ...
- bzoj1233 单调队列优化dp
https://www.lydsy.com/JudgeOnline/problem.php?id=1233 数据结构优化dp的代码总是那么抽象 题意:奶牛们讨厌黑暗. 为了调整牛棚顶的电灯的亮度,Be ...
- POJ1821 单调队列//ST表 优化dp
http://poj.org/problem?id=1821 当我们在考虑内层循环j以及决策k的时候,我们可以把外层变量i看作定值,以此来优化dp状态转移方程. 题意 有n个工人准备铺m个连续的墙,每 ...
- P3512 [POI2010]PIL-Pilots-洛谷luogu
刚研究完单调队列和单调栈 于是就找题做了 发现了这道蓝题 以为很简单 就着手来写了 然而 并不是我想的那样 只是有一点点思路 无奈 还是看了题解 好吧题解是真的挺好的 ---------------- ...
随机推荐
- JS中call、apply、bind
call就是挨个传值,apply传一个数组,bind也是挨个传值 call() 和 apply() 会执行这个函数bind并不会而是将绑定好的this重新返回一个新函数
- [转]B树与B+树----mysql的索引结构
B树 和B+树是 MySQL索引使用的数据结构,对于索引优化和原理理解都非常重要,下面我的写文章就是要把B树,B+树的神秘面纱揭开,让大家在面试的时候碰到这个知识点一往无前,不再成为你的知识盲点! 1 ...
- centons7.2 双网口聚合功能配置和验证
1.启动网络管理器运行systemctl restart NetworkManager2.创建主备绑定连接 nmcli connection add con-name bond0 type bond ...
- 输入流导致javax.crypto.BadPaddingException
使用FileInputStream一切正常,切换为使用classpath从jar包读取getResourceAsStream一直报如下错误 javax.crypto.BadPaddingExcepti ...
- SqlSugar 代码生成 数据库及表
在实际开发中如何在sqlsugar中通过model生成数据表呢? 废话不说上代码 一.引入sqlsugarcore 二.编写Model代码 先写一个model举例 namespace 用户管理.Mod ...
- gin web 2
routers/router.go package routers import ( "github.com/gin-gonic/gin" "gin-blog/pkg/s ...
- msvc去除控制台窗口的编译指令
#pragma comment(linker, "/subsystem:windows /ENTRY:mainCRTStartup")
- android HttpURLConnection ,HttpClient设置Cookie
上一阶段项目设计使用cookie信息实现登录访问功能,在实现过程遇到一些问题,下面整理一下: 首先,client想使用cookie,必须访问一次server从会话中获取cookie信息,然后在设置回去 ...
- 安全漏洞之grafana-cve_2021_43798
漏洞说明 一个可绕过用户登录进行任意文件读取的漏洞 环境搭建 我使用的是vulfocus提供的vulfocus/grafana-cve_2021_43798 ,由vulfocus后台统一管理 利用脚本 ...
- VisualSvn-Server搭建
一.安装VisualSvn-Server 1.安装向导 2.同意许可 3.选择组件 4.选择版本(选择"标准版本",企业版需要收费) 5.服务器设置 6.安装 7.安装中 8.安装 ...