数组超过预设的最大数组大小_算法--滑动窗口最大值数组

问题:

有一个整形数组nums和一个大小为k的窗口,窗口从数组的最左边每次滑动一格直到最右边,返回每次窗口中的最大值

Input: nums = [1,3,-1,-3,5,3,6,7], and k = 3

Output: [3,3,5,5,6,7]

Explanation:

Window position Max

--------------- -----

[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

分析

该问题暴力求解就是遍历整个数组,对每个滑动窗口排序求最大值,时间复杂度为O(NK),是否有O(N)的解法了,这里可以使用双向队列达到O(N)

解决

依次遍历整个数组,每次遍历的时候把值从尾部插入到双向队列中,但是有个条件,保证双向队列尾部的元素要大于该值,如果不大于就把尾部的值弹出,知道大于或者队列为空。这样可以保证滑动窗口向右扩张的时候随时都可以从双向队列头部取得滑动窗口的最大值。

什么时候从双向队列头部弹出值了,因为滑动窗口大小是固定的,所以向右滑动一个位置,可能导致左边的值失效,如果新的滑动窗口左边的值刚好是双向队列的最大值就直接从头部弹出,这样遍历完整个数组,就可以求到改值了,时间复杂度为O(N)

c79216f20f22d18253743a49e6ee8b2f.png

代码

37f435d8d48424eb7fa90a767ba2f8c7.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值