力扣1438.绝对差不超过限制的最长连续子数组

力扣1438.绝对差不超过限制的最长连续子数组

  • 难点:保存数组缩小后的最大最小值

    • 用两个单调队列分别处理最大值和最小值
cpp 复制代码
  class Solution {
  public:
      int longestSubarray(vector<int>& nums, int limit) {
          deque<int> quemax,quemin;
          int n = nums.size(),res=0;
          for(int i=0,j=0;i<n;i++)
          {
              while(!quemax.empty() && quemax.back() < nums[i]) quemax.pop_back();
              while(!quemin.empty() && quemin.back() > nums[i]) quemin.pop_back();
              quemax.push_back(nums[i]);
              quemin.push_back(nums[i]);
              while(!quemax.empty() && !quemin.empty() && quemax.front() - quemin.front() > limit)
              {
                  if(quemax.front() == nums[j]) quemax.pop_front();
                  if(quemin.front() == nums[j]) quemin.pop_front();
                  j ++;
              }
              res = max(res,i-j+1);
          }
          return res;
      }
  };
相关推荐
不爱吃炸鸡柳9 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
Aurorar0rua10 小时前
CS50 x 2024 Notes C - 05
java·c语言·数据结构
6Hzlia11 小时前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香11 小时前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut11 小时前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
寒秋花开曾相惜12 小时前
(学习笔记)4.1 Y86-64指令集体系结构(4.1.4 Y86-64异常&4.1.5 Y86-64程序)
开发语言·jvm·数据结构·笔记·学习
foundbug99913 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
自我意识的多元宇宙14 小时前
树、森林——树与二叉树的应用(哈夫曼树的构造)
数据结构
memcpy014 小时前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展