【LeetCode】239. 滑动窗口最大值

这题其实挺不好写的。知识点虽然重要,但细节非常繁琐,我这一次(20240709)花费了大概2个小时才写出这道题,但其实这还是我已经知道这道题是需要使用"单调队列"算法来求解,并我已事先学过单调队列算法了。所以知易行难,提升算法水平,还是需要老老实实的多敲代码。

1. 题目

题目的意思很好理解,就是求某个数组固定大小窗口内的最大值。

2. 分析

我写这部分代码的时候,犯了三个错误:

  • 应该先把当前的数同队列尾部的数比较,然后处理;
  • 当前的每个数都会被入队,但是后面入队的数可能会因为"质量"更高而把当前数从队尾移除
  • 不会熟练使用Python自身的队列结构,从而被迫使用数组模拟队列,导致代码变得复杂

3. 代码

python 复制代码
class Solution:
    def maxSlidingWindow(self, nums: List[int], k: int) -> List[int]:
        que = [0 for i in range(len(nums))]
        front = rear = 0
        res = []
        if k == 1:
            return nums
        for i in range(1, len(nums)):
            #关键点1:先把队尾处理了,再处理队首。原因很简单:队尾可能就是当前元素
            tail = que[rear]
            while(nums[i] >= nums[tail] and (i-tail) < k and rear >= 0):
                rear -= 1
                if rear>=0:
                    tail = que[rear]
			# 关键点2:无论当前来的是什么数,都会给它放到队列中
            rear+=1
            que[rear] = i
			
            head = que[front]
            while(i >= head + k and front <= rear):
                front += 1
                head = que[front]
            if (i >= k-1): # 可以构成一个窗口
                head = que[front]
                res.append(nums[head])
        return res
相关推荐
灰色小旋风1 分钟前
力扣21 合并两个有序链表(C++)
c++·leetcode·链表
2401_8914821730 分钟前
C++模块化编程指南
开发语言·c++·算法
沉鱼.4431 分钟前
树、堆的题目集
算法
暮冬-  Gentle°32 分钟前
自定义类型转换机制
开发语言·c++·算法
2301_8166512243 分钟前
嵌入式C++低功耗设计
开发语言·c++·算法
机器学习之心1 小时前
PSO-LightGBM-ABKDE粒子群算法优化轻量级梯度提升机自适应带宽核密度估计多变量回归区间预测Matlab实现
算法·matlab·回归·abkde·自适应带宽核密度估计·pso-lightgbm·粒子群算法优化轻量级梯度提升机
qq_416018721 小时前
分布式缓存一致性
开发语言·c++·算法
CoovallyAIHub1 小时前
多 Agent 手术推理框架:Agent 辩论+RAG 补上手术知识,零样本超越监督基线 14.6 个百分点
算法·架构·机器人
干啥啥不行,秃头第一名1 小时前
STL容器内部实现剖析
开发语言·c++·算法
Zarek枫煜1 小时前
zig与c3的冒泡排序算法
算法