首页 > 编程语言 > 详细

643. 子数组最大平均数 I

时间:2021-01-06 09:02:05      阅读:24      评论:0      收藏:0      [点我收藏+]

给定 n 个整数,找出平均数最大且长度为 k 的连续子数组,并输出该最大平均数。

 

示例:

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

提示:

1 <= k <= n <= 30,000。
所给数据范围 [-10,000,10,000]。

 

用滑动窗口哦 不然时间会超过限制~

class Solution {
public:
    double findMaxAverage(vector<int>& nums, int k) {
            int n = nums.size();
        double temp_ave = 0;
        double max_ave = -10000;
        double temp_sum = 0;
        for(int j = 0; j <  k; ++j)
        {
            temp_sum += nums[j];
        }
        temp_ave = temp_sum / k;
        max_ave = max(max_ave, temp_ave);
        for(int i = 1; i <= n - k; ++i)
        {
            temp_sum = temp_sum - nums[i - 1] + nums[i + k - 1];
            temp_ave = temp_sum / k;
            max_ave = max(max_ave, temp_ave);
        }
        return max_ave;
        
    }
};

643. 子数组最大平均数 I

原文:https://www.cnblogs.com/zx62136/p/14238510.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!