维护滑动窗口中的最大值与最小值

滑动窗口模板

维护最大值与最小值

示例题目: 1438. 绝对差不超过限制的最长连续子数组

方法一

队列的应用:双端队列

使用单调递增队列维护最小值
使用单调递减队列维护最大值

<?php
// php 中没有双端队列这个概念,只有 array
// 但是如果使用 array_shift 去掉首条元素,在数组特别大的时候,会超时,所以,我先将数组创建好,使用左右指针维护一个子数组
class Solution {
/**
* @param Integer[] $nums
* @param Integer $limit
* @return Integer
*/
function longestSubarray($nums, $limit) {
// 滑动窗口 + 双端队列
if (empty($nums)) {
return 0;
}
$left = $right = 0;
$minQue = $maxQue = array_fill(0, count($nums), 0);
$minL = $minR = 0;
$maxL = $maxR = 0;
$maxLen = 0;
while ($right < count($nums)) {
while ($minR-$minL > 0 && $nums[$right] < $minQue[$minR-1]) {
$minR--;
}
while ($maxR - $maxL > 0 && $nums[$right] > $maxQue[$maxR-1]) {
$maxR --;
}
$minQue[$minR++] = $nums[$right];
$maxQue[$maxR++] = $nums[$right];
while ($maxQue[$maxL] - $minQue[$minL] > $limit) {
if ($maxQue[$maxL] == $nums[$left]) {
$maxL++;
}
if ($minQue[$minL] == $nums[$left]) {
$minL++;
}
$left++;
}
$maxLen = max($maxLen, $right - $left + 1);
$right++;
}
return $maxLen;
}
}

方法二

使用复杂数据结构

  1. 红黑树
  2. 跳表
    这是暂不深入

参考

  1. 官方题解: 绝对差不超过限制的最长连续子数组
posted @   吴丹阳-V  阅读(200)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示