[算法练习]第三天:定长滑动窗口

643. 子数组最大平均数 I

切记,这里的三段式

右指针入队列-》判断-》左指针出队列以备下一次判断

因为这里只需要最后返回平均值,所以只需要最后进行强制类型转换为double即可,不需要提前把变量设置为double

cpp 复制代码
class Solution {
public:
    double findMaxAverage(vector<int>& nums, int k) {
        int ans = INT_MIN;
        int temp = 0;
        for(int right = 0; right < nums.size(); right++){
            // 右指针
            temp += nums[right];
            //判断
            int left = right - k + 1;
            if(left < 0) continue;
            ans = max(ans,temp);
            //左指针出队列,以备下一次入队列
            temp -= nums[left];
        }
        return (double)ans/k;
    }
};

1343. 大小为 K 且平均值大于等于阈值的子数组数目

思路一点没变

cpp 复制代码
class Solution {
public:
    int numOfSubarrays(vector<int>& arr, int k, int threshold) {
        int ans = 0;
        int temp = 0;
        for(int right = 0;right < arr.size();right++){
            temp += arr[right];

            int left = right - k + 1;
            if(left < 0) continue;
            if(temp >= threshold*k) ans++;

            temp -= arr[left];
        }
        return ans;
    }
};

2090. 半径为 k 的子数组平均值

思路很像,几乎没什么区别,这里注意示例元素和可能会超过int,要用long long;数组初始化使用-1会方便很多;

cpp 复制代码
class Solution {
public:
    vector<int> getAverages(vector<int>& nums, int k) {
        vector<int>ans(nums.size(),-1);
        long long temp = 0;
        for(int right = 0;right < nums.size();right++){
            temp += nums[right];
            
            int left = right - 2*k ;
            if(left < 0) continue;
            //判断
            ans[(left+right)/2] = temp/(2*k+1);

            temp -= nums[left];
        }
        return ans;
    }
};
相关推荐
MediaTea6 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z6 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
WBluuue6 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
风筝在晴天搁浅7 小时前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法
MATLAB代码顾问8 小时前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
代码飞天8 小时前
机器学习算法和函数整理——助力快速查阅
人工智能·算法·机器学习
jiushiapwojdap9 小时前
LU分解法求解线性方程组Matlab实现
数据结构·其他·算法·matlab
笨笨饿9 小时前
69_如何给自己手搓一个串口
linux·c语言·网络·单片机·嵌入式硬件·算法·个人开发
纽扣6679 小时前
【算法进阶之路】链表进阶:删除、合并、回文与排序全解析
数据结构·算法·链表
消失的旧时光-194310 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法