LeetCode刷题笔记 | 643 | 子数组最大平均数 | 双指针 | 滑动窗口 | 数组 | Java | 详细注释 | 三种解法

🙋大家好!我是毛毛张!
🌈个人首页: 神马都会亿点点的毛毛张 双指针在一定条件下可以转化成滑动窗口,这道题就是个很好的例子


LeetCode链接:643. 子数组最大平均数 I


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

提示:

  • n == nums.length
  • 1 < = k < = n < = 1 0 5 1 <= k <= n <= 10^5 1<=k<=n<=105
  • − 1 0 4 < = n u m s [ i ] < = 1 0 4 -10^4 <= nums[i] <= 10^4 −104<=nums[i]<=104

2.题解

2.1 暴力解法(超出时间限制)

java 复制代码
public class Solution {
    public double findMaxAverage(int[] nums, int k) {
        // 初始化最大平均值为负无穷
        double maxAverage = Double.NEGATIVE_INFINITY;

        // 遍历数组中的所有可能的长度为 k 的连续子数组
        for (int i = 0; i <= nums.length - k; i++) {
            // 计算当前子数组的和
            int sum = 0;
            for (int j = i; j < i + k; j++) {
                sum += nums[j];
            }
            // 计算当前子数组的平均值
            double average = (double) sum / k;
            // 更新最大平均值
            maxAverage = average > maxAverage ? average : maxAverage;
        }

        // 返回最大平均值
        return maxAverage;
    }
}

2.2 双指针

  • 由于每次都要计算平均值,所以在这里做一个处理,先求出长度为k的区间和的最大值,返回时再求平均
java 复制代码
class Solution {
    public double findMaxAverage(int[] nums, int k) {
        // 初始化最大和为最小整数值
        int maxSum = Integer.MIN_VALUE;
        // 左右指针初始化
        int left, right;
        // 当前窗口的和
        int sum = 0;
        
        // 遍历数组
        for (left = 0, right = 0; right < nums.length; right++) {
            // 将当前元素加入窗口和
            sum += nums[right];
            
            // 如果当前窗口大小等于 k,更新最大和
            if (right - left + 1 == k) {
                maxSum = Math.max(maxSum, sum);
            }
            
            // 当窗口大小大于等于 k 时,移动左指针
            while (right - left + 1 >= k) {
                // 将窗口左边界的元素移出和
                sum -= nums[left];
                // 移动左指针
                left++;
            }
        }
        
        // 返回最大和对应的平均值
        return (double) maxSum / k;
    }
}

2.3 双指针优化=>滑动窗口

  • 由于所求的窗口的长度是固定的,因此首先计算出数组前k个区间的和,然后再向后滑动区间
java 复制代码
public class Solution {
    public double findMaxAverage(int[] nums, int k) {
        // 计算第一个长度为 k 的子数组的和
        int maxSum = 0;
        for (int i = 0; i < k; i++) {
            maxSum += nums[i];
        }

        // 当前子数组的和
        int currentSum = maxSum;

        // 使用滑动窗口遍历数组中的其他可能的长度为 k 的连续子数组
        for (int i = k; i < nums.length; i++) {
            // 更新当前子数组的和
            currentSum = currentSum - nums[i - k] + nums[i];

            // 更新最大和
            if (currentSum > maxSum) {
                maxSum = currentSum;
            }
        }

        // 返回最大平均值
        return (double) maxSum / k;
    }
}
相关推荐
第二只羽毛4 分钟前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫
用户37215742613523 分钟前
使用 Java 删除 Word 文档中的水印
java
艾斯比的日常23 分钟前
Java 三色标记算法:并发垃圾回收的核心技术解析
java·开发语言·算法
CoovallyAIHub34 分钟前
抛弃LLM!MIT用纯视觉方法破解ARC难题,性能接近人类水平
深度学习·算法·计算机视觉
空空kkk35 分钟前
MyBatis——代理Dao方式的增删改查操作
java·数据库·mybatis
程序猿编码38 分钟前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince
Seven971 小时前
线性数据结构
java
带刺的坐椅1 小时前
Solon 不依赖 Java EE 是其最有价值的设计!
java·spring·web·solon·javaee
高洁011 小时前
具身智能-视觉语言导航(VLN)
深度学习·算法·aigc·transformer·知识图谱
青云交1 小时前
Java 大视界 -- 基于 Java 的大数据分布式存储在数字媒体内容存储与版权保护中的应用
java·性能优化·区块链·分布式存储·版权保护·数字媒体·ai 识别