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

一个完整的网站推广方案山东军辉建设集团有限公司 公司网站网址

一个完整的网站推广方案,山东军辉建设集团有限公司 公司网站网址,苏州正规制作网站公司,宁波北仑做网站题意描述: 给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回 滑动窗口中的最大值 。 示例: 输入:nums [1,3,-1,…

题意描述:

给你一个整数数组 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

输入:nums = [1], k = 1
输出:[1]


解题思路:
Alice: 你咋想起来做这道了 ?
Bob: 我其实是在做另一道题目,多重背包的优化之单调队列优化,但是我不知道什么是单调队列,所以我需要先做一下这道题,学习一些单调队列。
Alice: 所有,有什么思路吗 ?
Bob: 学习的话,想个十分钟吧,然后看题解得了。
15-minutes-later
Alice: 好吧,题解看明白了吗 ?
Bob: 有点迷,我还是先上手写一下吧。
Alice: 没通过吧,有几个概念你要先了解。队列知道吧,先进先出。双端队列知道吗?两边都能进,两边都能出。你老用 JavaScript 的话,应该知道数组的 push pop shift unshift 这些方法吧,这就是双端队列。
Bob: 然后呢 ?
Alice:你还得知道单调队列,还有这题为啥需要单调队列来解。单调队列就是,队列中的值是单调的,单调就是数学上的那个单调,单调递增或者单调递减或者单调不增或者单调不减。
Bob: 那为啥要用单调队列呢 ?
Alice: 还是得读题啊。这题不是让求解滑动窗口的最大值吗 ?然后数组长度最大 10^5,k 的取值最大也是 10^5,按照最大的计算量 k取最大长度的一半也就是 5*10^4 然后每次都求最大值,计算量也就是 10^5 * (5 * 10^4)^2也就是 2.5 * 10^14, 时间限制是 1s 的话,一定会超时的。
Bob: 所以我们需要单调队列 ?
Alice: 差不多,单调队列非常适合这道题,这道题是让求 k 时间窗口的最大值,单调队列的头或尾一定是最大值。我们只需要在窗口滑动的过程中不断地维护队列就可以了。
Bob: 怎么维护呢 ?
Alice: 这里有两个点需要注意。1是要在维护队列的过程中不断干掉超出 k 时间窗口的值,2是要及时干掉那些不需要的值,比如说 nums[i] > nums[i-1] 的时候,nums[i-1] 就没必要继续留在队列中了,要求的是最大值 nums[i]nums[i-1] 更大且更 ”年轻“ ,求最大值的时候 nums[i] 一定会覆盖 nums[i-1]。当然这里不止 i-1 前面 ”更老更小“ 的都应该干掉。
Bob: 所以我们的数据结构中还应该有下标,通过下标来计算某个值是否超出 k 时间窗口 ?
Alice: 对的,而另一个维护队列的时机就是在新元素入队之前,或者入队的时候。
Bob: 还有什么要注意的吗 ?
Alice: 有的,有两个点,一是初始化的时候也要维护单调队列,还有就是每次维护其实是在队首和队尾都要维护,队尾要干掉那些不必要的,队首要保证在 k 时间窗口内最大。
Bob: k 时间窗口最大我是这样理解的,队尾的维护会把比较小的干掉,这样队首元素出去之后,从队尾补上来的,应该总是剩下的最大的。
Alice: 对的。
Bob: 还是挺有技巧的,上代码吧。


代码:

/*** @param {number[]} nums* @param {number} k* @return {number[]}*/
var maxSlidingWindow = function(nums, k) {const ans = []// 初始化 queueconst queue = [];for(let i=0; i<k; ++i) {// 维护队尾,去除不必要的又老又小的值while (queue.length > 0 && queue[queue.length-1][0] <= nums[i]) {queue.pop();}// 新大值入队queue.push([nums[i], i]);}ans.push(queue[0][0]);for (let i=k; i<nums.length; ++i) {// 维护队尾,去除不必要的又老又小的值while (queue.length > 0 && queue[queue.length-1][0] <= nums[i]) {queue.pop();}// 新大值入队queue.push([nums[i], i]);// 维护队首while (queue.length > 0 && queue[0][1] + k <= i) {queue.shift();}ans.push(queue[0][0]);}return ans;
};

测试用例:

[9,10,9,-7,-4,-8,2,-6]
5
[10,10,9,2]

参考:

  • 题目链接
  • 相关题目-多重背包的单调队列优化
http://www.yayakq.cn/news/195926/

相关文章:

  • 基于php旅游网站的毕业设计松江网站建设多少钱
  • 优酷网站怎么做的哪个网站可以做付邮免费送活动
  • 湟中县公司网站建设四川掌上电力app下载
  • 重庆网站建设cq600企业为什么需要网站
  • 渭南网站建设哪家好合肥做公司网站公司
  • 自建站怎么接入支付英文seo是什么
  • 珠珠宝宝网网站站建建设设商贸公司寮步网站建设极致发烧
  • 做网站怎么插音乐电商网站如何制作
  • 聊城的网站制作公司大数据网站建设费用
  • 成都网站制作scgc软件外包公司排名
  • 外贸公司网站建设房产网站怎么做
  • 关于网站建设与维护的参考文献福州营销网站建设技术
  • 餐饮网站建设规划书阜宁做网站哪家公司好
  • 做网站的市场网站首页结构怎么写
  • 移动商城网站建设 深圳会议管理系统
  • 笔记本电脑可以做网站服务器网络销售促进的方式
  • 常州网站开发培训网站下拉框怎么做
  • 做网站sqlserver排序关键词排名手机优化软件
  • 自己做的网站怎么在百度搜索到wordpress 后台底部修改
  • windows优化大师好吗seo建站公司推荐
  • 企业网站栏目设计网店买卖有哪些平台
  • 上海网站开发外包跨境电商平台排行榜
  • 常州语言网站建设wordpress .less
  • 网站开发api中文手册chm北京网络seo经理
  • 温州企业网站音频文件放到网站空间里生成链接怎么做
  • 网站备案与服务器动漫设计学什么
  • 网站载入页面怎么做短剧小程序开发费用
  • 安徽手机版建站系统信息华为网络工程师培训费用
  • 做笔记的网站wordpress在线解析
  • 门户网站建设标准莱芜受欢迎的网站建设