码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 每天一道算法题(十一)——滑动窗口最大值_困难(中等)


    文章目录

    • 1、问题
    • 2、示例
    • 3、解决方法
      • (1)方法1——双指针
    • 总结


    1、问题

    给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。
    返回 滑动窗口中的最大值 。

    2、示例

    示例 1:
    输入: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
    示例 2:
    输入:nums = [1], k = 1
    输出:[1]

    3、解决方法

    (1)方法1——双指针

    let nums = [1,3,-1,-3,5,3,6,7], k = 3
    var maxSlidingWindow = function(nums, k) {
        // 1-1:定义左右指针(右指针 = 滑动窗口长度 = k的长度)
        let left = 0;right= k;
        let maxArray = []  // 1-2:定义一个接收最大值的数组
        let temp; // 1-3 定义一个接收左右指针切割后的数组
        // 2-1:遍历判断 右指针 小于等于  数组的长度
        while(right <= nums.length){
            // 3-1: 根据左右指针切割数组赋值给temp
            temp = nums.slice(left, right);
            // 3-2 将切割的数组获取最大值
            let max = Math.max(...temp)
            // 3-3 将获取的最大值插入到数组中
            maxArray.push(max);
            // 2-2 :左右指针 自增
            left++
            right++
        }
        // 4:返回最大值数组
        console.log('最大值的数组', maxArray);
    };
    maxSlidingWindow(nums, k);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    总结

    (1)难度: 困难(如果你了解了双指针思路的话:中等)
    (2)相同文章:
    每天一道算法题(八)——找出字符串中无重复字符的最长子串
    每天一道算法题(九)——寻找字符串中所有字母异位词的子串
    每天一道算法题(十)——获取和为k的子数组
    (3)其他:20分钟不到写出来的,感觉还可以。

  • 相关阅读:
    论文精读NMP:Neural Map Prior for Autonomous Driving
    Kafka系列之:日志清理
    vue3中使用v-model实现父子组件数据同步
    thinkphp8路由
    【反悔贪心】2022ICPC南京 G
    QPrinter、QPrinterInfo、QPageLayout
    IDEA插件的在线离线安装
    MySQL索引、事务与存储引擎
    【实践出真理】import和require的引入方式真的和网上说的一样吗
    73.【JavaWeb-01】
  • 原文地址:https://blog.csdn.net/weixin_44784401/article/details/134558084
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号