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;
    }
}
相关推荐
炽烈小老头19 小时前
【每天学习一点算法 2026/05/21】课程表
学习·算法
luoganttcc19 小时前
大模型是否即将到达算法极限
算法
叶小鸡19 小时前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
LuminousCPP19 小时前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
_日拱一卒19 小时前
LeetCode:114二叉树展开为链表
java·开发语言·算法
无小道20 小时前
Redis——哈希类型相关指令
redis·算法·哈希算法
凌波粒20 小时前
LeetCode--513.找树左下角的值(二叉树)
java·算法·leetcode
一个不知名程序员www20 小时前
算法学习入门---算法题DAY1
c++·算法
子琦啊20 小时前
构造函数、this指向和原型链机制
javascript·算法·贴图
WHS-_-202220 小时前
Millimeter Wave ISAC-SLAM: Framework and RFSoC Prototype
人工智能·算法·原型模式