page contents

python基础编程100例:第84期-基础技巧:滑动窗口 子数组最大平均数

本文讲述了python基础编程100例:第84期-基础技巧:滑动窗口 子数组最大平均数!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

attachments-2022-04-XsXFJu5E62490d41cca5b.png

本文讲述了python基础编程100例:第84期-基础技巧:滑动窗口 子数组最大平均数!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

第84期-基础技巧:滑动窗口 子数组最大平均数

1 问题描述

给你一个由 n 个元素组成的整数数组 nums 和一个整数 k 。

请你找出平均数最大且 长度为 k 的连续子数组,并输出该最大平均数。

任何误差小于 10-5 的答案都将被视为正确答案。


示例 1:

输入: nums = [1,12,-5,-6,50,3], k = 4

输出: 12.75

解释: 最大平均数 (12-5-6+50)/4 = 51/4 = 12.75


示例 2:

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

输出: 5.00000


初始代码


from typing import List

class Solution:

    def findMaxAverage(self, nums: List[int], k: int) -> float:

        #在此之间填写代码


print(Solution().findMaxAverage([1,12,-5,-6,50,3],4))

print(Solution().findMaxAverage([5],1))


2 解题思路

标签:滑动窗口

先算出数组从0下标到k-1下标之间的和sum, max=sum;

遍历从下标1开始到nums长度-1之间范围的元素,每次sum先减去i-1(上一个元素的值),再加上i+k-i的值,即窗口内最后一值,再与max作比较;

最终返回平均值


3 解题方法

from typing import List

class Solution:

    def findMaxAverage(self, nums: List[int], k: int) -> float:

        i,a=1,len(nums)

        t=x=sum(nums[0:k])

        while i+k<a+1:

            x=x-nums[i-1]+nums[i+k-1]

            if t<x:

                t=x

            i+=1

        return t/k


print(Solution().findMaxAverage([1,12,-5,-6,50,3],4))

print(Solution().findMaxAverage([5],1))

第1-3,13-14行: 题目中已经给出的信息,运行代码时要根据这些代码进行编辑

第4行: 定义变量i,a分别赋值1和nums列表的长度

第5行: 定义变量t,x并赋值nums前k个元素的和

第6行: 当i+k小于等于列表长度时,之后便无法截取k长度的列表了

第7行: 滑动窗口,改变x的值为新窗口的和

第8-9行: 判断该和是否大于t,是则赋值给t

第10行: i加一用于下次遍历

第11行: 返回平均值


代码运行结果为:

attachments-2022-04-EqEAax5662490d33e94ff.png

算法讲解

这里用到了基础技巧:滑动窗口,简单讲解下这个技巧:

什么是滑动窗口

滑动窗口,顾名思义,就是有一个大小可变的窗口,左右两端方向一致的向前滑动(右端固定,左端滑动;左端固定,右端滑动)。

可以想象成队列,一端在push元素,另一端在pop元素,如下所示:


假设有数组[a b c d e f g h]

一个大小为3的滑动窗口在其上滑动,则有:

[a b c]

  [b c d]

    [c d e]

      [d e f]

        [e f g]

          [f g h]


适用范围

- 1、一般是字符串或者列表

- 2、一般是要求最值(最大长度,最短长度等等)或者子序列

算法思想

- 1、在序列中使用双指针中的左右指针技巧,初始化 left = right = 0,把索引闭区间 [left, right] 称为一个窗口。

- 2、先不断地增加 right 指针扩大窗口 [left, right],直到窗口中的序列符合要求。

- 3、此时,停止增加 right,转而不断增加 left 指针缩小窗口 [left, right],直到窗口中的序列不再符合要求。同时,每次增加 left前,都要更新一轮结果。

- 4、重复第 2 和第 3 步,直到 right 到达序列的尽头。

思路其实很简单:第 2 步相当于在寻找一个可行解,然后第 3 步在优化这个可行解,最终找到最优解。左右指针轮流前进,窗口大小增增减减,窗口不断向右滑动。

更多相关技术内容咨询欢迎前往并持续关注六星社区了解详情。

想高效系统的学习Python编程语言,推荐大家关注一个微信公众号:Python编程学习圈。每天分享行业资讯、技术干货供大家阅读,关注即可免费领取整套Python入门到进阶的学习资料以及教程,感兴趣的小伙伴赶紧行动起来吧。

attachments-2022-05-3nTMcWEX6290858c0c2d2.jpeg

  • 发表于 2022-04-03 10:58
  • 阅读 ( 603 )
  • 分类:Python开发

0 条评论

请先 登录 后评论
轩辕小不懂
轩辕小不懂

2403 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. 小柒 1658 文章
  3. Pack 1135 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章