【C++刷题】力扣-#643-子数组最大平均数I

题目描述

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

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

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

示例

示例 1

bash 复制代码
输入:nums = [1,12,-5,-6,50,3], k = 4
输出:12.75
解释:最大平均数 (12-5-6+50)/4 = 51/4 = 12.75

示例 2

bash 复制代码
输入: nums = [5], k = 1
输出: 5.00000000000000

题解

这个问题可以通过滑动窗口的方法来解决。

  1. 初始化窗口:首先,我们计算数组中第一个长度为 k 的子数组的和。
  2. 滑动窗口:然后,我们滑动窗口遍历整个数组,对于每个新的窗口,我们减去窗口左侧的元素,加上窗口右侧的元素,以计算新的窗口和。
  3. 更新最大平均值:对于每个窗口,我们计算平均值,并更新最大平均值。
  4. 返回结果:遍历结束后,返回计算出的最大平均值。

代码实现

cpp 复制代码
double findMaxAverage(vector<int>& nums, int k) {
    double maxAverage = nums[0];
    int windowSum = 0;
    // 初始化窗口和
    for (int i = 0; i < k; ++i) {
        windowSum += nums[i];
    }
    maxAverage = (windowSum * 1.0) / k;

    // 滑动窗口
    for (int i = k; i < nums.size(); ++i) {
        windowSum = windowSum - nums[i - k] + nums[i];
        double windowSumAverage =  (windowSum * 1.0) / k;
        maxAverage = max(maxAverage, windowSumAverage);
    }

    return maxAverage;
}

复杂度分析

● 时间复杂度:O(n),其中 n 是数组 nums 的长度。我们只需要遍历一次数组。

● 空间复杂度:O(1),因为我们只使用了常数个额外变量。

这个算法通过使用滑动窗口来高效地计算每个连续子数组的和,从而找到平均值最大的 k 个连续的子数组。

相关推荐
zhangjw341 小时前
Java基础语法:变量、数据类型与运算符,从原理到实战
java·开发语言
yaoxin5211235 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
WBluuue5 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
NotFound4865 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
木子墨5165 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
Ava的硅谷新视界6 小时前
用了一天 Claude Opus 4.7,聊几点真实感受
开发语言·后端·编程
rabbit_pro6 小时前
Python调用onnx模型
开发语言·python
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
weixin_513449967 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
浪客川7 小时前
【百例RUST - 010】字符串
开发语言·后端·rust