当前位置: 首页 > news >正文

LeetCode hot100-11

题目描述

题目链接:滑动窗口最大值

给你一个整数数组 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

思路解析

核心思想:维护一个双向队列,该队列队首元素为当前窗口最大值的下标。

        遍历数组,将小于当前元素的队列末尾元素全部弹出,因为答案需要的是窗口中的最大元素,当窗口中有大的元素则较小的就不需要了,然后将当前元素下标放入队列中,并判断当前维护的最大值下标是否还在窗口中,如果不在需要弹出,最后将窗口中的最大值(队首元素)加入答案数组中。

        注意:在循环弹出元素时需要先进行队列判空,防止查询空队列的尾元素;第一次将队列最大值加入数组应该是在遍历到第一个窗口的尾元素的位置(i==k-1),所以当i>=k-1才向答案数组添加答案。

代码实现

class Solution {
public:vector<int> maxSlidingWindow(vector<int>& nums, int k) {vector<int> res;deque<int> dq;for(int i=0;i<nums.size();i++) {while(!dq.empty()&&nums[i]>=nums[dq.back()])//弹出队列中比当前元素小的元素dq.pop_back();dq.push_back(i);//放入当前元素if(dq.front()<i-k+1)//当队首元素超出窗口范围弹出dq.pop_front();if(i >= k - 1)//当遍历到第一个窗口尾元素向答案数组中加入当前最大值res.push_back(nums[dq.front()]);}return res;}
};

相关文章:

  • Silky-CTF: 0x02靶场
  • Linux中断与异常:内核的事件驱动引擎
  • 接口测试的用例设计
  • 2025年浙江安全员C证考试题库
  • 基于langchain的简单RAG的实现
  • 12、企业应收账款(AR)全流程解析:从发票开具到回款完成
  • 基于PyQt5的相机手动标定工具:原理、实现与应用
  • linux登陆硬件检测脚本
  • 打卡第35天:GPU训练以及类的Call方法
  • 阿姆达尔定律的演进:古斯塔夫森定律
  • HertzBeat的告警规则如何配置?
  • 如何做接口测试?
  • GPIO的内部结构与功能解析
  • Python趣学篇:Pygame重现《黑客帝国》数字雨
  • 八股学习-JS的闭包
  • Express 集成Sequelize+Sqlite3 默认开启WAL 进程间通信 Conf 打包成可执行 exe 文件
  • 全面解析 Windows CE 定制流程:从内核到设备部署
  • 垂起固定翼无人机应用及技术分析
  • 嵌入式系统:从技术原理到未来趋势(驱动程序篇)
  • 动态规划十大经典题型状态转移、模版等整理(包括leetcode、洛谷题号)
  • 设计做网站/自动的网站设计制作
  • 淄博外贸网站制作/自动app优化下载
  • 淘宝客做网站怎么做/百度竞价登陆
  • 公司做网站的费属于广告费么/智能建站系统
  • 在哪里做企业网站/友情链接吧
  • 淘宝客如何做淘宝客网站/湖南好搜公司seo