算法通关村第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;
    }
}
相关推荐
无限进步_7 分钟前
深入理解 C/C++ 内存管理:从内存布局到动态分配
c语言·c++·windows·git·算法·github·visual studio
长安er22 分钟前
LeetCode 34排序数组中查找元素的第一个和最后一个位置-二分查找
数据结构·算法·leetcode·二分查找·力扣
点云SLAM44 分钟前
C++ 中traits 类模板(type traits / customization traits)设计技术深度详解
c++·算法·c++模板·c++高级应用·traits 类模板·c++17、20·c++元信息
CoderYanger1 小时前
动态规划算法-两个数组的dp(含字符串数组):48.最长重复子数组
java·算法·leetcode·动态规划·1024程序员节
liu****1 小时前
9.二叉树(一)
c语言·开发语言·数据结构·算法·链表
sin_hielo1 小时前
leetcode 3577
数据结构·算法·leetcode
ACERT3331 小时前
04矩阵理论复习-矩阵的分解
算法·矩阵
csuzhucong2 小时前
快餐连锁大亨
算法
ssshooter2 小时前
小猫都能懂的大模型原理 1 - 深度学习基础
人工智能·算法·llm
慕容青峰2 小时前
【LeetCode 1925. 统计平方和三元组的数目 题解】
c++·算法·leetcode