优选算法——滑动窗口3(子数组)

🔥近津薪荼:个人主页

🎬个人专栏:《c语言基础知识详解》《c++基础知识详解》《Linux操作系统及网络基础知识分享》《近津薪荼的算法日迹》

**✨**每个优秀的人,

都有一段沉默的时光,

❄️那段时光是付出了很多努力,

却得不到结果的日子,我们把它叫做扎根

⭐️祝您也祝我早日破土而出,巨木参天。


1.上期参考代码

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int left =0,right=0,n=s.size(),ret=0;
        int hash[128]={0};//使用数组来模拟哈希表
        while(right<n)
        {
            hash[s[right]]++;//进窗口
            while(hash[s[right]]>1)
            {
                hash[s[left++]]--;
            }//出窗口
          
            ret=max(ret,right-left+1);
             right++;
        }
         return ret;
    }
};

2.本期知识点导图

3.本期要讲解的题目是:

最大连续1的个数 III

要点:

二进制数组(只有0和1)

子数组可以有k个0

返回最大子数组

这题本质上就是找最长符合条件的子数组

4.解题

4.1暴力解法

暴力枚举出所有子数组,找出最长的符合要求**(不超k个0)** 的子数组,时间复杂度O(N^2)

4.2优解

找子数组的问题非常符合我们滑动窗口的特点:用两个同向双指针维护一段连续区间(窗口信息),而滑动窗口可以直接把时间复杂度降到O(N)级别,这已经是我们做的第道找连续子串的问题了,以后碰到找连续子串,最好有"使用同向双指针"的条件反射。

本题思路和上体一样,使用数组模拟的哈希表来统计和维护窗口信息

代码逻辑:

1.进窗口:将元素扔进哈希表
2.逻辑判断:0的个数是否大于k
3.出窗口:如果是就出窗口,直至否(while)
4.更新信息:出完窗口之后,窗口里的子数组一定满足要求,在此时更新length最合适

5.下期要讲解的题目是:

找到字符串中所有字母异位词

各位下期见。

相关推荐
遨游xyz2 小时前
数据结构-栈
java·数据结构·算法
FPGA小迷弟2 小时前
基于FPGA实现HDMI接口,选型/核心技术
学习·fpga开发·verilog·fpga·modelsim
方便面不加香菜2 小时前
c++入门基础
c++
ghie90902 小时前
基于动态规划算法的混合动力汽车能量管理建模与计算
算法·汽车·动态规划
蓝海星梦2 小时前
GRPO 算法演进——裁剪机制篇
论文阅读·人工智能·深度学习·算法·自然语言处理·强化学习
小O的算法实验室2 小时前
2025年SEVC SCI2区,结合低差异序列和共轭梯度法的新型异构综合学习粒子群算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
新时代牛马2 小时前
CANopenNode 接口及 CANopenLinux 完整实现
网络·学习
雍凉明月夜2 小时前
瑞芯微RV1106G3板端部署
c++·人工智能·深度学习
Smart-Space2 小时前
cpphtmlbuilder-c++灵活构造html
c++·html