算法通关村第16关【青铜】| 滑动窗口思想

1. 滑动窗口的基本思想

一句话概括就是两个快慢指针维护的一个会移动的区间

固定大小窗口:求哪个窗口元素最大、最小、平均值、和最大、和最小

可变大小窗口:求一个序列里最大、最小窗口是什么

2. 两个入门题

(1)子数组最大平均数

思路:每次窗口向右滑动一格,大小不变为k,遍历一次数组结果就出来了

java 复制代码
class Solution {
    public double findMaxAverage(int[] nums, int k) {
        int left = 0;
        int right = k-1;
        double sum = 0;
        for(int i = 0;i<k;i++){
            sum += nums[i];
        }
        double res = sum/k;
        while(right<nums.length-1){
            right++;
            left++;
            sum = sum - nums[left-1] + nums[right];
            if(sum/k>res){
                res = sum/k;
            }
        }
        return res;
    }
}

(2)最长连续递增序列

思路:窗口是递增的序列,当符合递增条件时窗口扩大,当不符合递增窗口重置为当前right位置,用一个变量来记录最长的递增子序列长度(窗口长度)

java 复制代码
class Solution {
    public int findLengthOfLCIS(int[] nums) {
        if(nums.length == 1){
            return 1;
        }
        int left = 0;
        int right = 0;
        int count = 1;
        int res = 1;
        while(right<nums.length-1){
            if(nums[right+1]>nums[right]){
                count++;
                right++;
            }else{
                res = res<count ? count : res;
                count = 1;
                right++;
                left = right;
            }
        }
        return count > res ? count : res;
    }
}
相关推荐
he___H14 小时前
接雨水----解
leetcode
斯内科15 小时前
四胞胎素数:找出‌个位数分别是 1、3、7、9‌,且‌十位及更高位数字完全相同‌的质数,例如 11、13、17、19
算法·质数·素数·四胞胎素数
Hello.Reader16 小时前
算法基础(十二)——主方法:快速求解常见递归式
算法
小O的算法实验室16 小时前
2026年IEEE TITS,面向按需外卖配送调度的特定问题知识与基于学习元启发式算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
加勒比海带6616 小时前
目标检测算法——农林行业数据集汇总附下载链接【Plant】
大数据·图像处理·人工智能·算法·目标检测
洛水水16 小时前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
影sir17 小时前
不同测试数据下,该如何选择算法
算法·深度优先
潇湘散客17 小时前
CAX软件插件化设计实现牛刀小试
c++·算法·图形学·opengl
速易达网络17 小时前
2026,视觉算法正在经历一场静默革命
算法
WBluuue18 小时前
Codeforces 1094 Div1+2(ABCDE)
c++·算法