【优选算法 — 滑动窗口】滑动窗口小专题(一)

 


长度最小的子数组 

 长度最小的子数组


题目解析:

 

对于示例一

 对于剩下两种示例:

  解法一:暴力枚举  

把所有的子数组全部枚举出来,并且枚举出的每一个子数组求和判断,返回长度最小的子数组;


  时间复杂度 :

枚举子数组 N^2 ,求和 N —> O(N^3)


数组中全都是正整数,所以加的数越多,和就越大,所以这就可以利用单调性来优化

优化暴力枚举,要让时间复杂度从 O(N^3) 优化到 O(N^2)

我们先定义出左区间 left ,然后不着急枚举右区间 right,先定义一个变量 sum ,来统计以 left 为左区间的所有子数组的和:

刚刚的暴力枚举,是先枚举右边,并且每枚举一次,都要判断当前子数组是否是合适的子数组 ;

而优化的方法为,定义一个sum,在 right 向右枚举时,每枚举一个数,都把这个数加到 sum 上

优化后,就可以省去找到子数组后(找到合适的位置,固定 left 和 right ),从前往后遍历,再相加的步骤;

此时我们就找到了一个合适的子数组,长度为4,既然已经找到合适的子数组,并且数组中都是正整数,那么我们就没有必要再让 right 继续往后枚举了,因为要返回的是长度最小的子数组;

此时就需要让 left++,此时,我们不需要着急更新 right,先计算 新left 和当前 right 组成的子数组 sum 是否满足条件;

所以在找到合适的子数组后,处理好后,先要让 sum = sum - nums[left] ,再让 left++即可


解法二:利用单调性,使用 “同向双指针”(“滑动窗口”)


(如果遇到在 right++ 后 依旧是 sum > target ,让 left++,而不是 right--)

如果 sum < target,right++ (进窗口);sum > target,left++(出窗口) 

因为在找合适子数组的过程中,left 和 right 一直是向右移动的,right 在 left++ 之后,是不会回退的,所以叫“同向双指针” ,“同向双指针”,又叫“滑动窗口”;

当我们发现可以利用单调性,使得两个指针都可以不会退(本题因为给的数组元素都是正整数,可以利用单调性,进而运用“滑动窗口”思想)

  1. 先初始化左窗口和右窗口(用 left 和 right 标记左区间和右区间,区间代表窗口)
  2. 进窗口  (right++)
  3. 判断(这个题需要在判断结果的时候更新结果,其他题目可能在进窗口更新结果)
  4. 出窗口  (right++)
  5. 循环进窗口和出窗口的过程  (回退到判断的步骤)

(更新结果的步骤是就题论题的,有的题目是进窗口时更新结果,有的是判断的时候才更新结果) 

滑动窗口能保证正确性,因为通过利用单调性,规避了很多没有意义的枚举行为,一定能在不断更新的过程中,得到一个最终的结果,这个结果就一定是正确的。


  时间复杂度  

哪怕代码是两层 for 循环,但是根据实际情况,我们每一步操作都只会让 left 或者 right 向后移动一格,最坏的情况:

刚开始初始化好指针后,就在判断下执行进窗口的操作(right++),在right = length 后,程序又通过判断执行出窗口操作(left++),这种最坏的情况操作 left 和 right 的次数为 2N;

所以时间复杂度为 O(N)


  编写代码  


  错误代码: 

  正确代码 : 


  无重复字符的最长子串  


解法一:暴力枚举 + 哈希表(判断字符是否重复出现)


  • 暴力枚举,就是以某一个字符为起点,开始向后遍历字符串;
  • 并且把遍历到的每一个字符,都放入  hash 表 中,进行判断当前遍历字符是否重复出现;
  • 如果重复出现,则停止遍历,统计当前子串长度(哈希表中的元素个数),并且让起点向后挪动一位;

  时间复杂度:

分析最坏情况下的时间复杂度,最坏情况下,因为是暴力枚举,从起点开始向后遍历字符串,并且起点从 字符串的第一个元素 到 字符串的最后一个元素 ;这个过程枚举到的所有子串中,返回最大子串长度;

所以时间复杂度是 O(N^2)


我们定义 left 指针指向起点并且固定,right 指针从 left 指针开始遍历;

每次遍历到一个字符,就判断该字符是否出现在哈希表中;

直到来到出现重复字符的位置,并且 right 记录下该字符的位置 ;

如果是暴力枚举,在 right 指向重复字符位置,记录下当前子串长度;

记录下当前子串长度之后,left往后挪动一位,right 重新回到 left 指针的位置;

然后继续重复上述过程;


  方法二:滑动窗口  


当 right 到达重复字符的位置,然后统计当前子串的长度;

然后 left 向后挪,挪动到当前子串中,与 right 所指向的字符相同的字符,所在的位置的后一位;

此时,right 无需再像暴力枚举一样,又回到 left 之前的位置,因为在 left 按照上面的规则,移动好位置后,新的 left 与 right 之间,是没有重复元素的;

此时,继续向后挪动 right 即可;

上述情况,left 和 right 移动的方向相同,所以这种方法就是滑动窗口。

对于上面这种题,对于我们最重要的启发,就是能分析出为什么使用滑动窗口:


要想清楚这题的做法是滑动窗口,要能根据例子,推断出 left 和 right 两个指针不用回退,并且 left 和 right 的移动情况(不一定是只后挪一位)


  编写代码  


对于本题,我们并不需要真的去 new 一个哈希表,可以用数组模拟哈希表;

只需要 new 一个最大容量为 128 的数组即可,因为所有我们常见的字符数为128;

数组的下标表示,每个字符的 ASCLL 码值;

如果该字符出现一次,该字符的 ASCLL码值对应的数组下标元素 +1;


  时空复杂度  


  时间复杂度:


O(N),虽然有两层循环,但是与上一题类似,要根据具体的情况分析时间复杂度;


  空间复杂度:


 ​​

​​

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

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

相关文章

【数据集】【YOLO】【目标检测】安全帽识别数据集 22789 张,YOLO安全帽佩戴目标检测实战训练教程!

数据集介绍 【数据集】安全帽识别数据集 22789 张&#xff0c;目标检测&#xff0c;包含YOLO/VOC格式标注。数据集中包含2种分类&#xff1a;{0: head, 1: helmet}&#xff0c;分别是无安全帽和佩戴安全帽。数据集来自国内外图片网站和视频截图。检测场景为施工地工人安全帽佩…

Linux 系统结构

Linux系统一般有4个主要部分&#xff1a;内核、shell、文件系统和应用程序。内核、shell和文件系统一起形成了基本的操作系统结构&#xff0c;它们使得用户可以运行程序、管理文件并使用系统。 1. linux内核 内核是操作系统的核心&#xff0c;具有很多最基本功能&#xff0c;它…

飞书 富文本(Markdown)

飞书机器人webhook支持Markdown格式&#xff0c;包括表格 表格 |Syntax | Description |\n|-------- | -------- |\n|Header | Title |\n|Paragraph | Text |参考 富文本&#xff08;Markdown&#xff09;

R语言实战——一些批量对地理数据进行操作的方法

各位朋友在进行数据处理时&#xff0c;当有多张栅格影像时&#xff0c;如果我们都要进行同一操作时&#xff0c;一张一张做很繁琐&#xff0c;用ArcGIS模型构建器是一种比较好的方法。当然&#xff0c;今天小编新学了R语言上面进行批量裁剪&#xff0c;一起来学习一下吧&#x…

【时间之外】IT人求职和创业应知【31】

目录 新闻一&#xff1a;2024年“秦创原沣东杯”陕西省科技工作者创新创业大赛颁奖仪式暨沣东新城机器人产业发展大会盛大启幕 新闻二&#xff1a;声网CEO赵斌&#xff1a;RTE将成为生成式AI时代AI Infra的关键部分 新闻三&#xff1a;“5G工业互联网”融合应用试点城市名单…

使用ThorUi

摘要&#xff1a; 官网 今天遇到一个老项目&#xff0c;使用的是ThorUi组件库&#xff01;之前没有用过这组件库&#xff0c;所以记录一下不同框架是使用情况&#xff01; ThorUI 是一个基于 Thorium 的 UI 框架&#xff0c;用于构建跨平台的桌面应用程序。如果你打算使用 Thor…

科研绘图系列:R语言文章组合图形(barplot scatterplot)

文章目录 介绍加载R包数据下载清理环境设置计算资源数据处理图1图2图3图4图5图6图7图8图9系统信息介绍 R语言组合图形 加载R包 library(xlsx) library(reshape2) library(ggplot2) library(ggh4x) library(wbstats

内网部署web项目,外网访问不了?只有局域网能访问!怎样解决?

相关技术 要实现“内网部署&#xff0c;外网访问”&#xff0c;可以使用内网穿透、VPN技术、DMZ主机、端口映射等方法。以下是对这些方法的详细解释&#xff1a; 一、内网穿透 内网穿透是一种技术&#xff0c;它通过将内网设备映射到公网上的方式&#xff0c;实现外网访问内…

从零开始训练一个大语言模型需要多少天?

一&#xff0c;前言 在AI领域&#xff0c;训练一个大型语言模型&#xff08;LLM&#xff09;是一个耗时且复杂的过程。几乎每个做大型语言模型&#xff08;LLM&#xff09;训练的人都会被问到&#xff1a;“从零开始&#xff0c;训练大语言模型需要多久和花多少钱&#xff1f;”…

Halcon resistor.hedv 使用多个对焦级别提取深度

depth_from_focus * Extract depth using multiple focus levels * 使用多个对焦级别提取深度 Names : [] * 初始化一个空数组&#xff0c;用于存储图像名称 dev_close_window () * 关闭当前打开的图像窗口 for i : 1 to 10 by 1 * 循环开始&#xff0c;从1到10 …

C语言 | Leetcode C语言题解之第546题移除盒子

题目&#xff1a; 题解&#xff1a; int dp[100][100][100];int calculatePoints(int* boxes, int l, int r, int k) {if (l > r) {return 0;}if (dp[l][r][k] 0) {int r1 r, k1 k;while (r1 > l && boxes[r1] boxes[r1 - 1]) {r1--;k1;}dp[l][r][k] calcu…

玩的花,云产品也能拼团了!!!

说起拼单大家都不陌生&#xff0c;电商一贯的营销手段&#xff0c;不过确实可以给消费者省下一笔钱。双11到了&#xff0c;腾讯云产品也玩起了拼团&#xff0c;这明显是对开发人员和各企业的福利。 对于有云产品需求的个人或企业&#xff0c;这次绝对是难得的一次薅羊毛机会。…

win10@win10 配置openssh服务

1.下载离线包&#xff1a;https://github.com/PowerShell/Win32-OpenSSH/releases 2.然后管理员打开powershell&#xff0c;cd到这个安装包放置的目录中来&#xff0c;输入以下命令&#xff1a;powershell.exe -ExecutionPolicy Bypass -File install-sshd.ps1 此时要注意pow…

全面解析:网络协议及其应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 # 全面解析&#xff1a;网络协议及其应用 文章目录 网络协议概述定义发展历程主要优势 主要网络协议应用层协议传输层协议网络层…

webWorker基本用法

我们都知道js是一个单线程的语言&#xff0c;当线程堵塞时&#xff0c;可能会导致页面无法正常交互&#xff0c;如一些复杂的可视化处理。即使是异步处理&#xff0c;也只是将其暂存到任务队列中去&#xff0c;等主线程执行完后依然会从任务队列中取过去。 为此&#xff0c;js提…

【1】虚拟机安装

1.安装VMware WorkStation Pro VMware下载地址&#xff1a; 2.新建虚拟机 centos7下载地址&#xff1a;centos-7.9.2009-isos-x86_64安装包下载_开源镜像站-阿里云

2-149 基于matlab的LDPC译码性能分析

基于matlab的LDPC译码性能分析&#xff0c;LDPC&#xff08;Low-Density Parity-Check&#xff09;码作为编码技术&#xff0c;具有优秀的纠错性能和较低的编解码复杂度。为保证可靠的数据传输&#xff0c;对传输过程中可能出现的信道噪声、干扰等进行模拟和分析。分析对比了误…

游戏开发--C#面试题

游戏开发--C#面试题 C#1. 值类型和引用类型的区别2. 重载和重写的区别3. ArrayList和List的区别4. List底层是什么实现的&#xff1f;5. 抽象类和接口的区别6. 静态成员和⾮静态成员的区别7. 装箱和拆箱是指什么&#xff1f;8. 值和引用类型在变量赋值时的区别是什么&#xff1…

DAY23|回溯算法Part02|LeetCode: 39. 组合总和 、40.组合总和II 、131.分割回文串

目录 LeetCode: 39. 组合总和 基本思路 C代码 LeetCode: 40.组合总和II 基本思路 C代码 LeetCode: 131.分割回文串 基本思路 C代码 LeetCode: 39. 组合总和 力扣代码链接 文字讲解&#xff1a;LeetCode: 39. 组合总和 视频讲解&#xff1a;带你学透回溯算法-组合总和…

【linux】再谈网络基础(二)

8. 再谈端口号 &#xff08;一&#xff09;与协议之间的关系 端口号(Port)标识了一个主机上进行通信的不同的应用程序 在TCP/IP协议中, 用 "源IP", "源端口号", "目的IP", "目的端口号", "协议号" 这样一个五元组来标识…