题目描述

给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值。例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}; 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2,5],1}, {2,3,4,2,6,[2,5,1]}。
 

解答:

用一个双端队列模拟当前的窗口。
首先队列维护非递增序,因为如果队列中有增序的数字,比如a,b,c为当前队列,有a<c。那么显然当前窗口中a一定不是最大值,并且a也不可能是之后某个窗口的最大值(因为c的索引在a之后,a先滑出窗口)。故a也就没有存储的必要。那么递减的数字为什么要存储呢?比如数组3,2,1,窗口大小k=2。那么起初的窗口为[3,2],队列为3,2。窗口右移一位,3被移出窗口,此时队列剩下2,由于1比2小故push,则队列中此时为2,1。那么如果之前不保存元素2,后面的窗口如果需要用到2(此例就用到了),便会出错。
 
模拟一个栗子以加深对滑动窗口的理解:
 
数组{2,3,4,2,6,2,5,1},窗口长度k=3
 
窗口[2,3,4],队列[4],实际是push2,pop2,push3,pop3,push4。
窗口[3,4,2],2<=4,所以push2,得队列[4,2]
窗口[4,2,6],6>2,pop2,此时队列[4],6>4,pop4,push6,得队列[6]
窗口[2,6,2],2<=6,所以push2,得队列[6,2]
窗口[6,2,5],5>2,pop2,此时队列[6],5<=6,push5,得队列[6,5]
窗口[2,5,1],由于6等于移出队列的元素,pop_front(6),此时队列[5],1<=5,push1,得队列[5,1]
 
每一步得到的队列的队首就是当前窗口的最大值,分别为4,4,6,6,6,5
 

代码:

队列存元素:

 class Solution {
public:
vector<int> maxInWindows(const vector<int>& num, unsigned int size)
{
if(size== or num.size()<size){return {};}
int k=size;
deque<int> que;
vector<int> res;
int le=,ri=;
while(ri<num.size()){
while(ri-le<k){
while(not que.empty() and que.back()<num[ri]){
que.pop_back();
}
que.push_back(num[ri++]);//存元素
}
res.push_back(que.front());
le++;
if(que.front()==num[le-]){
que.pop_front();
}
}
return res;
}
};

队列中保存数组索引也可以:

 class Solution {
public:
vector<int> maxInWindows(const vector<int>& num, unsigned int size)
{
if(num.size()<size){return {};}
int k=size;
deque<int> que;
vector<int> res;
int le=,ri=;
while(ri<num.size()){
while(ri-le<k){
while(not que.empty() and num[que.back()]<num[ri]){
que.pop_back();
}
que.push_back(ri++);//存索引
}
res.push_back(num[que.front()]);
le++;
if(que.front()==le-){
que.pop_front();
}
}
return res;
}
};

剑指offer 面试题. 滑动窗口的最大值的更多相关文章

  1. 剑指 Offer 59 - I. 滑动窗口的最大值 + 双指针 + 双端队列

    剑指 Offer 59 - I. 滑动窗口的最大值 Offer_59_1 题目详情 方法一:暴力方法+双指针 package com.walegarrett.offer; /** * @Author ...

  2. 力扣 - 剑指 Offer 59 - I. 滑动窗口的最大值

    题目 剑指 Offer 59 - I. 滑动窗口的最大值 思路1(单调队列) 使用单调(递减)队列,保持队列中的元素是递减顺序,队列头保存的是当前窗口中最大的元素 首先先模拟建立第一个窗口,同时获取第 ...

  3. 剑指offer系列38----滑动窗口的最大值(不懂????????????????????????????????????????????????)

    [题目] 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6 ...

  4. 剑指Offer:面试题15——链表中倒数第k个结点(java实现)

    问题描述 输入一个链表,输出该链表中倒数第k个结点.(尾结点是倒数第一个) 结点定义如下: public class ListNode { int val; ListNode next = null; ...

  5. 剑指offer面试题3 二维数组中的查找(c)

    剑指offer面试题三:

  6. 剑指Offer——笔试题+知识点总结

    剑指Offer--笔试题+知识点总结 情景回顾 时间:2016.9.23 12:00-14:00 19:00-21:00 地点:山东省网络环境智能计算技术重点实验室 事件:笔试 注意事项:要有大局观, ...

  7. C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...

  8. C++版 - 剑指offer 面试题23:从上往下打印二叉树(二叉树的层次遍历BFS) 题解

    剑指offer  面试题23:从上往下打印二叉树 参与人数:4853  时间限制:1秒  空间限制:32768K 提交网址: http://www.nowcoder.com/practice/7fe2 ...

  9. C++版 - 剑指offer 面试题39:判断平衡二叉树(LeetCode 110. Balanced Binary Tree) 题解

    剑指offer 面试题39:判断平衡二叉树 提交网址:  http://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222?tpId= ...

随机推荐

  1. Linux进程间通信-管道深入理解(转)

    原文地址:https://www.linuxidc.com/Linux/2018-04/151680.htm Linux进程通信系列文章将详细介绍各种通信方式的机制和区别 1.进程间通信 每个进程各自 ...

  2. git需要设置再次弹出输入账号密码

    今天在用命令行pull线上代码到本地时遇到一个尴尬的问题,因为新下载的git貌似默认了在pull,push代码时只弹出一次输入账号密码,反正我这里是这样的. 开始在pull线上代码的时候不小心密码输错 ...

  3. Pikachu-Unsafe Filedownload(不安全的文件下载)

    不安全的文件下载概述 文件下载功能在很多web系统上都会出现,一般我们当点击下载链接,便会向后台发送一个下载请求,一般这个请求会包含一个需要下载的文件名称,后台在收到请求后 会开始执行下载代码,将该文 ...

  4. MVC开发模式以及Smarty模板引擎的使用

    Linux 全局安装 composer 将目录切换到/usr/local/bin/目录 cd /usr/local/bin/ 在 bin 目录中下载 composer curl -sS https:/ ...

  5. JS 自动关闭页面

    <script language=javascript> this.window.opener = null; window.close(); </script>

  6. tensor数据基操----索引与切片

    玩过深度学习图像处理的都知道,对于一张分辨率超大的图片,我们往往不会采取直接压平读入的方式喂入神经网络,而是将它切成一小块一小块的去读,这样的好处就是可以加快读取速度并且减少内存的占用.就拿医学图像处 ...

  7. maven发布java-分支构建

    1.安装parameter插件 2. 新建maven项目 3.配置maven项目 4.配置maven项目2 5.配置maven项目3 6. 模拟开发给提交打tag标签 7.版本发布 8.tag获取并构 ...

  8. 【Hibernate】hibernate原生sql利用transformers返回多表自定义类型对象

    大致结构: Person(人): id,name,age,bookId Book(书):id,bookName Author(作者):id,authorName,bookId 一个人 只有 一本书,一 ...

  9. 剑指offer-面试题24-反转链表-链表

    /* 题目: 定义一个函数,输入链表的头结点,反转链表输出反转后链表的头节点. */ /* 思路: 记录当前节点的next和pre. 断开当前节点指向next的指针,指向pre. */ #includ ...

  10. [POI2004]PRZ [枚举子集]

    怎么全是 模拟退火 啊,这明明是个 枚举子集 的板子题. 考虑 \(n \leq 16\) 二进制没错了.. \(dt_i\) 表示 \(i\) 这个状态下 \(\max{t_j}\),\([\tex ...