leetcode滑动窗口(leetcode滑动窗口万能公式)

技术LeetCode怎样找出滑动窗口的最大值小编给大家分享一下LeetCode怎样找出滑动窗口的最大值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一

边肖将与您分享LeetCode如何找出滑动窗口的最大值。相信大部分人还不太了解,所以分享这篇文章给大家参考。希望大家看完这篇文章后收获多多。让我们一起来发现吧!

00-1010给定一个数组nums和滑动窗口的大小k,请找出所有滑动窗口中的最大值。

00-1010输入: 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

00-1010考虑到这个问题的数组要求,头可以进,可以删,尾可以进,可以删,所以用的是得克得克。使用德格的单调的德格LinkedList实现。

所谓单调性,就是我们人为指定存储的元素从队列的头到尾依次递减(或递增)。

也就是说,我们维持着单调的双向队列。每次窗口滑动时,我都会从队列头取当前窗口中的最大值。每次窗口中出现一个元素,我都会将其大小与队列中的元素进行比较:

如果刚进来的元素比队列末尾的元素大,那么先弹出队列末尾的元素,再把刚进来的元素加到队列末尾;

如果刚进来的元素小于队列末尾的元素,只需将刚进来的元素直接添加到队列末尾。

因此,窗口的最大值可以通过这种可以从头部和尾部进出的结构来保持。

题目描述:

#-*-coding : utf-8-*-

类别解决方案:

defmaxInWindows(自身,数量,大小):

#writecodehere

#存储可能是最大值的下标

maxqueue=[]

#存储窗口中的最大值

maxlist=[]

n=透镜(数量)

#参数检查

ifn==0orsize==0orsizen:

returnmaxlist

foriirange(n):

#确定对应于队列头下标的元素是否滑出窗口。

iflen(max queue)0 Andi-size=max queue[0]:

(=NationalBureauofStandards)国家标准局

p;  maxqueue.pop(0)
            while len(maxqueue) > 0 and num[i] > num[maxqueue[-1]]:
                maxqueue.pop()
            maxqueue.append(i)
            if i >= size - 1:
                maxlist.append(num[maxqueue[0]])
        return maxlist

 
 

java代码:

class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        Deque<Integer> deque=new LinkedList<>();
        int len=nums.length;
        if(len==0 ||k==0 ){
            return new int[0] ;
        }
        int[] res=new int[len-k+1];
        
        for(int i=0;i<k;i++){
            while(!deque.isEmpty() && nums[i]>deque.peekLast()){
                deque.removeLast(); //比队列元素大就弹出队尾数据
            
            }
            deque.addLast(nums[i]);//不走循环直接加到队列末尾
            
        }
        res[0]=deque.peekFirst();
        for(int i=k;i<len;i++){
            // 如果滑动窗口已经略过了队列中头部的元素,则将头部元素弹出
            if(deque.peekFirst() == nums[i - k]){
                deque.removeFirst();//
            }
            while(!deque.isEmpty() && deque.peekLast() < nums[i]){
                deque.removeLast();
            }
            deque.addLast(nums[i]);
            res[i - k + 1] = deque.peekFirst();


        }
        return res;
    }
}

以上是“LeetCode怎样找出滑动窗口的最大值”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/147019.html

(0)

相关推荐

  • 0392-判断子序列

    技术0392-判断子序列 0392-判断子序列给定字符串 s 和 t ,判断 s 是否为 t 的子序列。
    字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串

    礼包 2021年12月5日
  • 如何利用Cloudflare为基于GitHub Pages的Hexo博客添加HTTPS支持

    技术如何利用Cloudflare为基于GitHub Pages的Hexo博客添加HTTPS支持这篇文章将为大家详细讲解有关如何利用Cloudflare为基于GitHub Pages的Hexo博客添加HTTPS支持,文章内

    攻略 2021年11月12日
  • java反编译工具都有哪些(java防止反编译免费工具)

    技术Java反编译工具有哪些这篇文章主要介绍“Java反编译工具有哪些”,在日常操作中,相信很多人在Java反编译工具有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java反编译工具

    攻略 2021年12月24日
  • php+apache安装QQ微信网址域名防被封售卖系统源码怎么编写

    技术php+apache安装QQ微信网址域名防被封售卖系统源码怎么编写这篇文章将为大家详细讲解有关php+apache安装QQ微信网址域名防被封售卖系统源码怎么编写,文章内容质量较高,因此小编分享给大家做个参考,希望大家

    攻略 2021年10月23日
  • web编程技巧有哪些

    技术web编程技巧有哪些本篇内容主要讲解“web编程技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web编程技巧有哪些”吧!您应该使用像map、filter和red

    攻略 2021年11月11日
  • 必知必会的 Vim 编辑器基础命令有哪些呢

    技术必知必会的 Vim 编辑器基础命令有哪些呢本篇文章为大家展示了必知必会的 Vim 编辑器基础命令有哪些呢,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。为什么推荐 Vim 编辑

    攻略 2021年11月12日