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

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;}
};

http://www.xdnf.cn/news/10853.html

相关文章:

  • JS深拷贝与浅拷贝
  • 数据加密标准(DES)解析及代码实现(java)
  • 解决IDEA插件使用Lombok找不到符号问题
  • Transformer核心原理
  • C++实现图形化2048小游戏
  • torch.distributed.launch 、 torchrun 和 torch.distributed.run 无法与 nohup 兼容
  • 如何避免工具过多导致的效率下降
  • Java函数式编程(下)
  • 机器人开发前景洞察:现状、机遇、挑战与未来走向
  • 2024-2025-2-《移动机器人设计与实践》-复习资料-8……
  • 【基础】Unity中Camera组件知识点
  • SpringBoot 和 Spring 的区别是什么?
  • 动物超声波记录仪应用场景和厂家
  • Python训练打卡Day41
  • Spring Bean 为何“难产”?攻克构造器注入的依赖与歧义
  • AI+在线教育系统源码:开发智能化互动网校平台全流程详解
  • 【相机基础知识与物体检测】更新中
  • 【北邮 操作系统】第十三章 I/O系统
  • 高考数学易错考点01 | 临阵磨枪
  • Spine工具入门教程4之网格与权重
  • SpringAI系列 - MCP篇(三) - MCP Client Boot Starter
  • 【C++高级主题】多重继承下的类作用域
  • 面向对象系统中对象交互的架构设计哲学
  • 集成学习之Bagging,Boosting,随机森林
  • Vue3 + Vite:我的 Qiankun 微前端主子应用实践指南
  • 杭州白塔岭画室怎么样?和燕壹画室哪个好?
  • LEAP模型
  • MongoDB-6.0.24 主从复制搭建和扩容缩容详解
  • Java垃圾回收机制深度解析:从理论到实践的全方位指南
  • 【Typst】4.导入、包含和读取