LeetCode-239. 滑动窗口最大值【队列 数组 滑动窗口 单调队列 堆(优先队列)】

news/2024/5/20 8:06:20 标签: leetcode, python, 算法, 单调队列, 滑动窗口

LeetCode-239. 滑动窗口最大值【队列 数组 滑动窗口 单调队列 堆(优先队列)】

  • 题目描述:
  • 解题思路一:其实是一道队列题,单调队列。队头是最大值,依次递减,所以需要在入队出队的时候维护单调队列的时候。
  • 解题思路二:优化,单调队列
  • 解题思路三:

题目描述:

给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。

返回 滑动窗口中的最大值 。

示例 1:

输入:nums = [1,3,-1,-3,5,3,6,7], k = 3
输出:[3,3,5,5,6,7]
解释:
滑动窗口的位置 最大值


[1 3 -1] -3 5 3 6 7 3
1 [3 -1 -3] 5 3 6 7 3
1 3 [-1 -3 5] 3 6 7 5
1 3 -1 [-3 5 3] 6 7 5
1 3 -1 -3 [5 3 6] 7 6
1 3 -1 -3 5 [3 6 7] 7
示例 2:

输入:nums = [1], k = 1
输出:[1]

提示:

1 <= nums.length <= 105
-104 <= nums[i] <= 104
1 <= k <= nums.length

解题思路一:其实是一道队列题,单调队列。队头是最大值,依次递减,所以需要在入队出队的时候维护单调队列的时候。

python">from collections import deque
class MyQueue():
    def __init__(self):
        self.deque = deque()
    def pop(self, value):
        if self.deque and value == self.deque[0]:
            self.deque.popleft() # 是O(1), list.pop()时间复杂度为O(n)
    def push(self, value):
        while self.deque and value > self.deque[-1]:
            self.deque.pop()
        self.deque.append(value)
    def front(self):
        return self.deque[0]

class Solution:
    def maxSlidingWindow(self, nums: List[int], k: int) -> List[int]:
        que = MyQueue()
        res = []
        for i in range(k):
            que.push(nums[i])
        res.append(que.front())
        for i in range(k, len(nums)):
            que.pop(nums[i-k])
            que.push(nums[i])
            res.append(que.front())
        return res
        

时间复杂度:O(n)
空间复杂度:O(k)

解题思路二:优化,单调队列

python">from collections import deque
class Solution:
    def maxSlidingWindow(self, nums: List[int], k: int) -> List[int]:
        q = deque() # 双端队列
        res = []
        for i, num in enumerate(nums):
            while q and nums[q[-1]] <= num: # 入队前维护
                q.pop() # 维护q的单调性
            q.append(i) # 入队
            if i - q[0] >= k: # 队首(最大值)离开窗口
                q.popleft()
            # 每个窗口记录一次答案,在i >= k - 1之后
            if i >= k - 1:
                res.append(nums[q[0]])
        return res

时间复杂度:O(n)
空间复杂度:O(k)

解题思路三:

python">

时间复杂度:O(n)
空间复杂度:O(n)


http://www.niftyadmin.cn/n/5463699.html

相关文章

VR全景赋能智慧农业,打造沉浸式种植体验平台

随着人口的增长&#xff0c;传统农业也正在面临着不一样的挑战&#xff0c;加上很多人对农业的固有印象&#xff0c;很少有年轻人愿意下到农田里&#xff0c;那么该如何提高产量、降低成本以及引导年轻人深刻感受现代农业成为了急需解决的问题。 随着城市化脚步的推进&#xff…

AI绘图cuda与stable diffusion安装部署始末与避坑

stable diffusion的安装说起来很讽刺&#xff0c;最难的不是stable diffusion&#xff0c;而是下载安装cuda。下来我就来分享一下我的安装过程&#xff0c;失败了好几次&#xff0c;几近放弃。 一、安装cuda 我们都知道cuda是显卡CPU工作的驱动&#xff08;或者安装官网的解释…

SpringBoot微服务实现深度学习:构建AGI道路的基石+实战案例演示

&#x1f389;&#x1f389;欢迎光临&#xff0c;终于等到你啦&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;持续更新的专栏《Spring 狂野之旅&#xff1a;从入门到入魔》 &a…

Python位操作指南:从基础到应用

前言 位操作允许直接在二进制层面上直接操作整数的各个位&#xff0c;使用位操作解决问题能降低很多时间和空间复杂度&#xff0c;以很低的成本很优雅的解决问题&#xff0c;不过有着一定的学习成本。 正文 负数和二进制表示 知识补充&#xff1a; 在计算机中&#xff0c;…

如何查找合适自己的EI期刊和会议?

大家都知道EI工程索引包含期刊和会议&#xff0c;两者含金量都是比较高的&#xff0c;那么如何才能找到适合自己的EI期刊和会议?ei期刊数量众多&#xff0c;ei国际会议举办次数也是很多的&#xff0c;下面分享几种查找的渠道仅供参考&#xff1a; 渠道一、通过搜索引擎查找&am…

软件测试工作中需要的Linux知识,一篇文章就够了

01、Linux基础 1、Linux系统简单介绍 Linux是一套免费使用, 支持多用户、多任务、支持多线程和多个核心CPU的操作系统&#xff1b;很多中型, 大型甚至是巨型项目都在使用Linux。 Linux的发行版说简单点就是将Linux与应用软件做一个打包, 目前市面上比较知名的发行版有: Ubun…

C++ | Leetcode C++题解之第2题两数相加

题目&#xff1a; 题解&#xff1a; class Solution { public:vector<int> twoSum(vector<int>& nums, int target) {map<int,int> a;//提供一对一的hashvector<int> b(2,-1);//用来承载结果&#xff0c;初始化一个大小为2&#xff0c;值为-1的容…

关于一篇知乎答案的重现

〇、前言 早上在逛知乎的时候&#xff0c;瞥见了一篇答案&#xff1a;如何通俗解释Docker是什么&#xff1f;感觉很不错&#xff0c;然后就耐着性子看了下&#xff0c;并重现了作者的整个过程。但是并不顺利&#xff0c;记载一下这些坑。嫌麻烦的话可以直接clone 研究&#xf…