力扣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;
      }
  };
相关推荐
超级大只老咪11 分钟前
快速进制转换
笔记·算法
m0_7066532333 分钟前
C++编译期数组操作
开发语言·c++·算法
故事和你9143 分钟前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_423233901 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder1231 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_715575341 小时前
分布式任务调度系统
开发语言·c++·算法
naruto_lnq1 小时前
泛型编程与STL设计思想
开发语言·c++·算法
踩坑记录2 小时前
leetcode hot100 94. 二叉树的中序遍历 easy 递归 dfs
leetcode
zxsz_com_cn2 小时前
设备预测性维护算法分类及优劣势分析,选型指南来了
算法·分类·数据挖掘