LeetCoded第239题题解--滑动窗口最大值
滑动窗口最大值
给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。
返回滑动窗口中的最大值。
进阶:
你能在线性时间复杂度内解决此题吗?
示例:
输入: 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
提示:
1 <= nums.length <= 10^5
 -10^4 <= nums[i] <= 10^4
 1 <= k <= nums.length
解题思路
一: 移动窗口,扫描,获取最大值,假设数组里有n个元素,算法的复杂度是O(n)。
 二: 利用一个双端队列来保存当前窗口中最大那个数在数组里的下标,双端队列新的头就是当前窗口最大的那个数。通过该下标,可以很快知道新窗口是否仍包含原来那个最大的数。如果不包含,我们就把旧数据同双端队列头删除。
java解法
 public int[] maxSlidingWindow(int[] nums, int k) {
        //处理边界值, 定义变量消除魔法值
        int min = 2;
        if (nums==null||nums.length< min){
            return nums;
        }
        //创建双向队列
        Deque<Integer> deque = new LinkedList<>();
        //创建结果数组
        int[] result = new int[nums.length-k+1];
        for (int i = 0; i < nums.length; i++) {
            //判断入值是否小于队尾值,保证队列大小顺序,确保最大值位于对头
            while (deque.size()!=0&&nums[deque.peekLast()]<nums[i]){
                deque.removeLast();
            }
            //将数据加入队列
            deque.addLast(i);
            //移除超出窗口的数据
            if (deque.peekFirst()<=i-k){
                deque.removeFirst();
            }
            //从第k-1个值开始存入最大值
            if (i+1>=k){
                result[i+1-k] = nums[deque.peekFirst()];
            }
        }
        return result;
    }
												
											LeetCoded第239题题解--滑动窗口最大值的更多相关文章
- Java实现 LeetCode 239 滑动窗口最大值
		
239. 滑动窗口最大值 给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧.你只可以看到在滑动窗口内的 k 个数字.滑动窗口每次只向右移动一位. 返回滑动窗口中的最 ...
 - 代码随想录第十三天 | 150. 逆波兰表达式求值、239. 滑动窗口最大值、347.前 K 个高频元素
		
第一题150. 逆波兰表达式求值 根据 逆波兰表示法,求表达式的值. 有效的算符包括 +.-.*./ .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 注意 两个整数之间的除法只保留整数部分. ...
 - Leetcode 239.滑动窗口最大值
		
滑动窗口最大值 给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧.你只可以看到在滑动窗口 k 内的数字.滑动窗口每次只向右移动一位. 返回滑动窗口最大值. 示例: ...
 - [Swift]LeetCode239. 滑动窗口最大值 | Sliding Window Maximum
		
Given an array nums, there is a sliding window of size k which is moving from the very left of the a ...
 - [Leetcode]双项队列解决滑动窗口最大值难题
		
这道题是从优先队列的难题里面找到的一个题目.可是解法并不是优先队列,而是双项队列deque 其实只要知道思路,这一道题直接写没有太大的问题.我们看看题 给定一个数组 nums,有一个大小为 k 的滑动 ...
 - Q239 滑动窗口最大值
		
给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧.你只可以看到在滑动窗口 k 内的数字.滑动窗口每次只向右移动一位. 返回滑动窗口最大值. 示例: 输入: nums ...
 - 滑动窗口最大值的golang实现
		
给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧.你只可以看到在滑动窗口 k 内的数字.滑动窗口每次只向右移动一位. 返回滑动窗口最大值 输入: nums = [, ...
 - LeetCoded第25题题解--K个一组翻转链表--java--链表
		
链表 单链表:链表中的每个元素实际上是一个单独的对象,而所有对象都通过每个元素的引用字段链接在一起. 双链表:与单链表不同的是,双链表的每个节点都含有两个引用字段. 链表优点 灵活分配内存空间 能在O ...
 - Leetcode 239题 滑动窗口最大值(Sliding Window Maximum) Java语言求解
		
题目链接 https://leetcode-cn.com/problems/sliding-window-maximum/ 题目内容 给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧 ...
 
随机推荐
- Kubernetes实战:高可用集群的搭建和部署
			
摘要:官方只提到了一句"使用负载均衡器将 apiserver 暴露给工作节点",而这恰恰是部署过程中需要解决的重点问题. 本文分享自华为云社区<Kubernetes 高可用集 ...
 - 【LeetCode】151. 翻转字符串里的单词(剑指offer 58-I)
			
151. 翻转字符串里的单词 知识点:字符串:双指针 题目描述 给你一个字符串 s ,逐个翻转字符串中的所有 单词 . 单词 是由非空格字符组成的字符串.s 中使用至少一个空格将字符串中的 单词 分隔 ...
 - Java成长之路--一个非科班生的进阶之路
			
前言 笔者从事Java开发六年有余,从什么都不懂的小白一路成长到上市公司管理20人的技术leader.管理的团队,虽然人数不算多,但也是对于我这个非科班生这么多年努力的一种肯定.在技术的道路上,我没有 ...
 - 如何掌握C#的核心技术
			
如何掌握C#的核心技术 感谢网友毛大神制作的图. 引子 前不久看到一个段子,某年宁波交警引进人脸识别技术抓拍行人闯红灯,结果一天下来被发现闯红灯次数最多的是珠海女子董小姐,日闯红灯3000多次.宁波交 ...
 - Windows配置深度学习环境详细教程(一):安装Pycharm和Miniconda、conda环境介绍
			
序言 对于想要入门Python或者深度学习的初学者而言,配置环境一直是一个令人头疼的问题.相信有许多人经历过安装第三方包失败,安装好了却在使用中报错,安装CUDA.tensorflow.pytorch ...
 - TCP协议的“三次握手”和“四次挥手”
			
TCP是面向连接的,无论哪一方向另一方发送数据之前,都必须先在双方之间建立一条连接.在TCP/IP协议中,TCP 协议提供可靠的连接服务,连接是通过三次握手进行初始化的.三次握手的目的是同步连接双方的 ...
 - Python -- 值转换为字符串的两种机制
			
可以通过以下两个函数来使用这两种机制:一是通过str函数,它会把值转换为合理形式的字符串,以便用户可以理解:而repr会创建一个字符串,它以合法的Python表达式的形式来表示值.下面是一些例子: & ...
 - django中路由配置的正则
			
在django中配置路由遇到正则的坑: django2.x版本中使用re_path来进行正则表达式的匹配 用法如下: from Django.urls import re.path(导入re_path ...
 - 2020国防科大综述:3D点云深度学习—综述(点云形状识别部分)
			
目录 摘要 1.引言: 2.背景 2.1 数据集 2.2评价指标 3.3D形状分类 3.1基于多视图的方法 3.2基于体素的方法 3.3基于点的方法 3.3.1 点对多层感知机方法 3.3.2基于卷积 ...
 - 浏览器中hook对象属性
			
先获取window对象属性 来源: 夜幕爬虫安全论坛 原文链接: http://bbs.nightteam.cn/thread-485.htm?orderby=desc&user=7