优选算法——滑动窗口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.下期要讲解的题目是:

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

各位下期见。

相关推荐
知识分享小能手4 小时前
Redis入门学习教程,从入门到精通,Redis 概述:知识点详解(1)
数据库·redis·学习
张李浩6 小时前
Leetcode 054螺旋矩阵 采用方向数组解决
算法·leetcode·矩阵
big_rabbit05026 小时前
[算法][力扣101]对称二叉树
数据结构·算法·leetcode
red_redemption6 小时前
自由学习记录(135)
学习
美好的事情能不能发生在我身上6 小时前
Hot100中的:贪心专题
java·数据结构·算法
myloveasuka6 小时前
Java与C++多态访问成员变量/方法 对比
java·开发语言·c++
2301_821700537 小时前
C++编译期多态实现
开发语言·c++·算法
奥地利落榜美术生灬7 小时前
c++ 锁相关(mutex 等)
开发语言·c++
xixihaha13247 小时前
C++与FPGA协同设计
开发语言·c++·算法
小小怪7507 小时前
C++中的函数式编程
开发语言·c++·算法