LeetCode643. 子数组最大平均数 I

题干

给你一个由 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

提示:

  • n == nums.length
  • 1 <= k <= n <= 105
  • -10^4 <= nums[i] <= 10^4

解题思路

这道题是典型的滑动窗口 类型的题目。以示例一入手来看题目,k=4,每4个数为一组,由于题目中所说是连续子数组,我们可以将前4个数的和sum算出来,当作最大值max,然后这个可以容纳4个数的窗口向右移动一位,将原本的总和sum减去第一个数,加上下一个数,得到下一组子数组的和,并将其与最大值max作比较,取更大的值做max。以此类推,得到所有连续子数组的和并得到最大的和max。

需要注意,我们得到的和max是int型的,需要通过 max * 1.0 来将其变为double型,确保除法可以得到正确的结果。

AC代码

java 复制代码
class Solution {
    public double findMaxAverage(int[] nums, int k) {
            int sum = 0;
            int n = nums.length;
            for(int i=0;i<k;i++){
                sum = sum + nums[i];
            }
            int max = sum;
            for(int i=k;i<n;i++){
                sum = sum - nums[i-k] + nums[i];
                max = Math.max(max,sum);
            }
            return 1.0 * max / k;
    }
}
相关推荐
一起养小猫6 分钟前
《Java数据结构与算法》第三篇(下)队列全解析:从基础概念到高级应用
java·开发语言·数据结构
WolfGang00732124 分钟前
代码随想录算法训练营Day28 | 509.斐波那契数列、70.爬楼梯、746.使用最小花费爬楼梯
算法
Boop_wu27 分钟前
[Java EE] 多线程进阶(JUC)(2)
java·jvm·算法
闻缺陷则喜何志丹1 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
CoovallyAIHub1 小时前
如何在手机上轻松识别多种鸟类?我们发现了更简单的秘密……
深度学习·算法·计算机视觉
别动哪条鱼1 小时前
AVAudioFifo
数据结构·ffmpeg·音视频
第二只羽毛2 小时前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫
艾斯比的日常2 小时前
Java 三色标记算法:并发垃圾回收的核心技术解析
java·开发语言·算法
CoovallyAIHub2 小时前
抛弃LLM!MIT用纯视觉方法破解ARC难题,性能接近人类水平
深度学习·算法·计算机视觉
程序猿编码2 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince