力扣第239题 c++滑动窗口经典题 单调队列

题目

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

思路和解题方法

  1. 定义了一个名为Solution的类,其中包含了一个嵌套类myqueue
  2. myqueue类使用deque来实现一个单调队列,具有三个方法:poppushfront
  3. maxSlidingWindow方法接收一个整数数组nums和窗口大小k作为参数,用于求解滑动窗口的最大值。
  4. 在方法中,首先创建一个myqueue对象que,并将前k个元素依次插入队列中(通过调用myqueue类的push方法)。
  5. 然后将队列的首元素(即最大值)加入到结果向量ans中。
  6. 接下来,从第k个元素开始遍历数组nums,每次循环:
    • 先将窗口外的元素从队列中移出(通过调用myqueue类的pop方法)。
    • 然后将当前元素插入到队列中(通过调用myqueue类的push方法)。
    • 再将队列的首元素加入到结果向量ans中。
  7. 最后,返回结果向量ans作为最终的结果。

复杂度

        时间复杂度:

                O(n)

时间复杂度为O(n),其中n表示数组nums的大小。因为每个元素最多进出队列一次,所以总共有2n次操作,因此时间复杂度为O(n)。

        空间复杂度

                O(k)

空间复杂度是O(k),其中k为窗口大小。因为单调队列中最多存储k个元素,所以空间复杂度为O(k)。值得注意的是,如果窗口大小为1,即每个元素都被作为一个窗口进行处理,那么空间复杂度将是O(n)。

c++ 代码

 ​
class Solution {
public:
    class myqueue{
        public:
            deque<int>que; // 使用deque作为存储队列元素的容器

            void pop(int value) // 弹出value,如果当前队列的首元素等于value
            {
                if(!que.empty() && value == que.front()) // 如果队列不为空且队列首元素等于value
                    que.pop_front(); // 弹出队列首元素
            }

            void push(int value) // 将value插入队列中
            {
                while(!que.empty() && value > que.back()) // 如果队列不为空且value大于队列末尾元素
                    que.pop_back(); // 弹出队列末尾元素,以保持队列单调递减
                que.push_back(value); // 插入value到队列末尾
            }
            int front(){ // 返回队列的首元素
                return que.front();
            }
            
    };
public:
    vector<int> maxSlidingWindow(vector<int>& nums, int k) {
        myqueue que; // 创建一个myqueue对象
        vector<int> ans; // 存储结果的向量
        for(int i = 0; i < k; i++) // 初始化窗口的大小,将前k个元素插入队列中
        {
            que.push(nums[i]);
        }
        ans.push_back(que.front()); // 将队列的首元素(当前窗口的最大值)加入结果向量中
        for(int i = k; i < nums.size(); i++) // 从第k个元素开始遍历数组
        {
            que.pop(nums[i - k]); // 弹出窗口外的元素
            que.push(nums[i]); // 将当前元素插入队列中
            ans.push_back(que.front()); // 将队列的首元素加入结果向量中
        }
        return ans; // 返回结果向量
    }
};

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。


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

相关文章

transformer系列4---transformer结构计算量统计

transformer计算量 1 术语解释2 矩阵相乘FLOPs3 Transformer的FLOPs估计3.1 MultiHeadAttention3.1.1 Q,K,V计算3.1.2 attention计算3.1.3 MultiHeadAttention输出线性映射3.1.4 MultiHeadAttention总计算量 3.2 MLP3.3 projection输出3.3 计算量累计 1 术语解释 FLOPs&#xf…

含分布式电源的配电网可靠性评估(matlab代码)

目录 1 主要内容 2 部分代码 3 程序结果 4 下载链接 1 主要内容 该程序参考《基于仿射最小路法的含分布式电源配电网可靠性分析》文献方法&#xff0c;通过概率模型和时序模型分别进行建模&#xff0c;实现基于概率模型最小路法的含分布式电源配电网可靠性评估以及时序模型…

从0开始python学习-29.selenium 通过cookie信息进行登录

1. 手动输入cookie信息保持登录状态 url https://test.com/login driver.get(url) # 手动将cookie信息写入&#xff08;有多个的情况需要分开写入&#xff09;--弊端为需要每次都手动输入&#xff0c;很麻烦不适用 driver.add_cookie({"name": "SIAM_IMAGE_…

短期风速预测|LSTM|ELM|批处理(matlab代码)

目录 1 主要内容 LSTM-长短时记忆 ELM-极限学习机 2 部分代码 3 程序结果 4 程序链接 1 主要内容 该程序是预测类的基础性代码&#xff0c;程序对河北某地区的气象数据进行详细统计&#xff0c;程序最终得到pm2.5的预测结果&#xff0c;通过更改数据很容易得到风速预测结…

【2023年11月第四版教材】第17章《干系人管理》(第二部分)

第17章《干系人管理》&#xff08;第二部分&#xff09; 4 过程1-识别干系人4.1 数据收集★★★4.3数据分析4.4 权力利益方格4.5 数据表现&#xff1a;干系人映射分析和表现★★★ 5 过程2-规划干系人参与5.1 数据分析5.2 数据表现★★★5.2.1 干系人参与度评估矩阵★★★ 5.3 …

QGIS文章二——DEM高程裁剪和3D地形图

经常看到别人基于高程文件制作出精美的3D地图&#xff0c;笔者按照互联网几种制作方式进行尝试后&#xff0c;写的DEM高程裁剪和3D地形图教程&#xff0c;或许其中有一些错误的&#xff0c;也请指出。 本文基于海南省的shp文件和海南省DEM高程文件&#xff0c;制作海口地区的3D…

windows下导入备份的sql

背景&#xff1a; 发现导入线上的数据库(数据量很多)&#xff0c;用GUI工具发现总是出问题&#xff0c;改为命令后没问题&#xff0c;所以我现在更相信命令行的力量。 1.一般sql中没有数据库创建&#xff0c;因此我们可以用 HeidiSQL先创建数据库 2.选择数据库 // 账号密码登…

WSL2安装历程

WLS2安装 1、系统检查 安装WSL2必须运行 Windows 10 版本 2004 及更高版本&#xff08;内部版本 19041 及更高版本&#xff09;或 Windows 11。 查看 Windows 版本及内部版本号&#xff0c;选择 Win R&#xff0c;然后键入winver。 2、家庭版升级企业版 下载HEU_KMS_Activ…