滑动窗口详解

news2024/11/25 6:57:25

滑动窗口本质其实也是一种双指针算法,只是因为它维护的区间随着遍历的进行在不停变化,所以形象地称为“滑动窗口”

一、⻓度最⼩的⼦数组

 题目要求找到满足条件的长度最小的子数组,我们先来想想暴力的做法,再来想想能不能优化,一般来说,这种找子数组的暴力,就是两层for循环枚举左右两个端点,找到符合条件的所有子数组,然后找出最小值,下面画个图给大家分析一下

 代码如下

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int ans=nums.size()+1;
        for(int left=0,right=0,s=0;right<nums.size();right++){
            //进窗口
            s+=nums[right];
            //判断是否需要出窗口
            while(s>=target){
                //更新答案
                ans=min(ans,right-left+1);
                s-=nums[left++];
            }
        }
        return ans==nums.size()+1?0:ans;
    }
};

通过这道题,我们就能总结出一些规律,滑动窗口的题目分为三个步骤,进窗口,判断是否出窗口以及何时更新答案,当然前提是你得先判断出这题是用滑动窗口解

二、将x减到0的最⼩操作数


这题如果你开始模拟左右两个区间之和==x,而没有想过转化条件,那它就会很难解决,但是其实题目可以等价成找元素和==sum(nums)-x的最长子数组的长度,最后用数组长度减去最长子数组长度就能得到最小操作数,而等价后的题目明显和上一道题几乎一样,这里就不具体分析了

代码如下

class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int n=nums.size();
        int target=accumulate(nums.begin(), nums.end(), 0)-x;
        if(target<0) return -1;//注意判断边界条件
        int ans=n+1;
        for(int left=0,right=0,s=0;right<nums.size();right++){
            //进窗口
            s+=nums[right];
            //判断是否出窗口
            while(s>target) 
                s-=nums[left++];
            //更新答案
            if(s==target) 
                ans=min(ans,n-(right-left+1));
        }
        return ans==n+1?-1:ans;
    }
};

好,经过上面的题目,我们就已经对滑动窗口的题目更多的认识和了解,关键在于发现题目可以用滑动窗口解决以及维护区间的某些属性,同时两个指针往同一方向移动(即满足某种单调性)---滑动窗口的特征

三、⽔果成篮
 

这道题目就是维护区间内水果类型是否大于2,思路如下

 进窗口-判断是否出窗口-更新答案 的细节在下面的代码里(请细品)

class Solution {
public:
    int totalFruit(vector<int>& fruits) {
        int n=fruits.size(),ans=0;
        int cnt[n];
        memset(cnt,0,sizeof(cnt));
        for(int left=0,right=0,s=0;right<n;right++){
            //进窗口
            if(++cnt[fruits[right]]==1)//出现次数为1次,说明水果种类增加
                s+=1;
            //判断是否出窗口
            while(s>2){
                if(--cnt[fruits[left++]]==0)//出现次数为0次,说明水果种类减少
                    s-=1;
            }
            ans=max(ans,right-left+1);
        }
        return ans;
    }
};

四、找到字符串中所有字⺟异位词

 这题跟上面几题不太一样,这题的窗口长度是固定的,就是查看字符串s中p.size()的窗口有几个是和组成p的字符一样,记录下标,步骤还是 进窗口-判断是否出窗口-更新答案 

代码如下

class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
        vector<int>ans;
        int hash1[26]={0},hash2[26]={0},k=p.size(),cout=0;
        for(int i=0;i<p.size();i++)
            hash1[p[i]-'a']++;
        for(int left=0,right=0;right<s.size();right++){
            //进窗口
            char in=s[right];
            //如果加完之后该字符的数量任然<=p中该字符的数量,说明增加的是有效字符,cout++
            if(++hash2[in-'a']<=hash1[in-'a']) cout++;
            //出窗口
            if(right-left+1>k){
                char out=s[left++];
                //如果该字符的个数本就<=p中该字符的数量,说明减少的是有效字符,cout--
                if(hash2[out-'a']--<=hash1[out-'a'])cout--;
            }
            //更新答案
            if(k==cout) ans.push_back(left);
        }
        return ans;
    }
};

 总结:牢记滑动窗口的三个步骤:进窗口,判断是否出窗口以及何时更新答案,稍难的滑动窗口一般都是和哈希表结合起来,主要是在判断进窗口和出窗口的条件上下文章,当然一切的前提是你能想到用滑动窗口来解决问题,当问题和维护一段连续区间的属性有关时,我们就可以想一想滑动窗口

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1004156.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LeetCode 1462. 课程表 IV:拓扑排序

【LetMeFly】1462.课程表 IV&#xff1a;拓扑排序 力扣题目链接&#xff1a;https://leetcode.cn/problems/course-schedule-iv/ 你总共需要上 numCourses 门课&#xff0c;课程编号依次为 0 到 numCourses-1 。你会得到一个数组 prerequisite &#xff0c;其中 prerequisite…

npm 清缓存(重新安装node-modules)

安装node依赖包的会出现失败的情况&#xff0c;如下图所示&#xff1a; 此时 提示有些依赖树有冲突&#xff0c;根据提示 “ this command with --force or --legacy-peer-deps” 执行命令即可。 具体步骤如下&#xff1a; 1、先删除本地node-modules包 2、删掉page-loacl…

redis实战-redis实现异步秒杀优化

秒杀优化-异步秒杀思路 未优化的思路 当用户发起请求&#xff0c;此时会请求nginx&#xff0c;nginx会访问到tomcat&#xff0c;而tomcat中的程序&#xff0c;会进行串行操作&#xff0c;分成如下几个步骤 1、查询优惠卷 2、判断秒杀库存是否足够 3、查询订单 4、校验是否是一…

vue中如何给特殊字段设置插槽

大纲: <template><div><div><span>卡号</span><el-input type"text" v-model"cardNo" clearable placeholder"请输入卡号" /><el-button type"primary" plain icon"el-icon-search"…

【Python】从入门到上头— 多进程与分布式进程(10)

文章目录 前言一.多进程1.fork()系统调用2.OS模块3.multiprocessing模块4.进程池&#xff08;multiprocessing Pool模块&#xff09;5.子进程&#xff08;subprocess模块&#xff09;6.进程间通信7.小结7.1.学习小结7.2.Python分布式进程报错&#xff1a;pickle模块不能序列化l…

Axure RP 10汉化版下载 Axure RP 10 mac授权码

Axure RP10汉化版是最强大的计划&#xff0c;原型设计和交付给开发人员的方法&#xff0c;而无需编写代码。能够制作逼真的&#xff0c;动态形式的原型。 Axure RP 10汉化版下载 Axure RP 10 mac授权码 RP 10有什么新功能&#xff1f; 1.显示动态面板 使用Axure RP 10&…

【FAQ】安防监控/视频汇聚/云存储/智能视频分析平台EasyCVR显示CPU过载,如何解决?

视频云存储/安防监控/视频汇聚平台EasyCVR基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。安防视频监控系统EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;具体可实现视频监控直播、视频轮播、视频录像、云…

环境变量与Path环境变量

“环境变量”和“path环境变量”其实是两个东西&#xff0c;这一点大家一定要区分开&#xff0c;不要混为一谈。 “环境变量”是操作系统工作环境设置的一些选项或属性参数。每个环境变量由变量名和文件路径组成的&#xff0c;可以设置很多个环境变量。 我们一般使用环境变量…

把数组b中的值拷贝给数组a numpy.copyto(a,b)

【小白从小学Python、C、Java】 【计算机等级考试500强双证书】 【Python-数据分析】 把数组b中的值拷贝给数组a numpy.copyto(a,b) [太阳]选择题 请问关于以下代码最后输出结果的是&#xff1f; import numpy as np to np.array([1, 2]) print("【显示】to ",to) …

GLTF扩展使用及开发指南

glTF 扩展扩展了基本 glTF 模型格式。 扩展可以引入新的属性&#xff08;包括引用外部数据的属性&#xff0c;并且扩展可以定义这些数据的格式&#xff09;、新的参数语义、保留的 ID 和新的容器格式。 扩展是针对特定版本的 glTF 编写的&#xff0c;并且可能会在更高版本的 gl…

高忆管理:央行利好提振 A股三大指数收红

上证指数日K线图 受央行利好音讯刺激&#xff0c;9月11日A股商场震荡走强&#xff0c;三大指数收红&#xff0c;北上资金日内“去而复返”&#xff0c;由净流出转为净流入。 因为上周末音讯面略显平平&#xff0c;9月11日A股开盘较为分解&#xff0c;三大指数涨跌不一&#x…

518企业年会抽奖软件,支持撤消、轮空缺席弃奖

518抽奖软件简介 518抽奖软件&#xff0c;518我要发&#xff0c;超好用的年会抽奖软件&#xff0c;简约设计风格。 包含文字号码抽奖、照片抽奖两种模式&#xff0c;支持姓名抽奖、号码抽奖、数字抽奖、照片抽奖。(www.518cj.net) 操作入口 主窗口上按 CtrlZ&#xff0c;打开…

Linux入门-网络基础|网络协议|OSI七层模型|TCP/IP五层模型|网络传输基本流程

文章目录 一、网络基础 二、网络协议 1.OSI七层模型 2.TCP/IP五层&#xff08;或四层&#xff09;模型 三、网络传输基本流程 1.网络传输流程图 2.数据包封装和分用 四、网络中的地址管理 1.IP地址 2.MAC地址 一、网络基础 网络发展最初是独立模式&#xff0c;即计算…

系统学习Linux-防火墙(Firewall)

目录 防火墙的作用 防火墙分类 防火墙性能 硬件防火墙 软件防火墙 扩展&#xff1a;Web应用防火墙(WAF) 硬件防火墙与软件防火墙比较 iptables netfilter/iptables功能 iptables概念 iptables工作一句——规则&#xff08;rules&#xff09; iptables中链的概念 i…

【面试必刷TOP101】反转链表 链表内指定区间反转

目录 题目&#xff1a;反转链表_牛客题霸_牛客网 (nowcoder.com) 题目的接口&#xff1a; 解题思路&#xff1a; 代码&#xff1a; 过啦&#xff01;&#xff01;&#xff01; 题目&#xff1a;链表内指定区间反转_牛客题霸_牛客网 (nowcoder.com) 题目的接口&#xff1…

肖sir__mysql之安装__002

mysql之安装 1、rpm -qa|grep mysql 2.删除mysql的方法&#xff1a; 第一种&#xff1a;yum remove mysql * &#xff08;*表示所有&#xff09; 第二种&#xff1a;rpm -e --nodeps 包名 强制删除mysql包 3、删除干净mysql文件&#xff0c;在进行安装 yum install mysql 安装…

MAML在隐式神经表示中的应用

论文 Learned Initializations for Optimizing Coordinate-Based Neural Representations &#x1f383;Abstract1. Introduction2. Related Work3. Overview ⭐4. Results5. Conclusion6. AcknowledgementsA. Implementation details Implicit Neural Representations for Ima…

Linux IO函数

read/write函数&#xff1a; 1.read #include <unistd.h> ssize_t read(int fd, void *buf, size_t count); 参数&#xff1a; -fd&#xff1a;文件描述符&#xff0c;open得到的&#xff0c;通过这个文件描述符操作某个文件 -buf&#xff1a;需要读取数据存放的地方…

3D虚拟情景实训教学系统在法律课堂中的应用

3D虚拟情景实训教学系统是一种基于虚拟现实技术的教育工具&#xff0c;它通过模拟真实的法律场景&#xff0c;让学生能够身临其境地体验法律实践。这种教学方式可以让学生更加深入地理解法律原则和规则&#xff0c;提高他们的法律素养和实践能力。 在传统的法律课堂中&#xff…

一文了解国自然热点“超级增强子”的重要标记——H3K27ac

2023国自然结果已经揭晓&#xff0c;“超级增强子”&#xff08; Super enhancer, SE&#xff09;作为国自然新热点&#xff0c;2023年项目为32个。2019-2023年来总累计项目143项&#xff0c;但累计项目金额达6033万。此外&#xff0c;Pubmed数据统计显示5年间SE影响因子大于10…