【C++】滑动窗口:最大连续1的个数

1.题目

2.算法思路

其实在做这道题的时候并不需要真的把0翻转成1,只需要找到最长的子数组且该子数组中0的个数不大于K,就可以了!

当然我们首先想到的是暴力穷举法:

找到所有符合题意的子数组,跳出最长的那个就可以了。需要嵌套的两层循环,时间复杂度是O(N^2),对于一个在Leetcode上中等难度的题目来说大概率会运行超时,所以我们需要对暴力穷举法进行优化。

那么我们需要同向的双指针left和right来作为子数组的两个端点,用计数器size统计0的个数,用len来记录最大子数组的长度。

当size>K时->left++,这时right不用再回来,因为right回来后它还是会在原来的位置停下来(根据零的个数),所以我们需要不停的往右移动left,知道它越过一个0后停止。

上图是滑动窗口的具体解法步骤。

总结:

当一个题目是对一个区间进行判断,一般问最大最小等问题时往往用到滑动窗口。

再说一下:滑动窗口就是同向的双指针算法。

3.提交结果与代码实现

cpp 复制代码
class Solution {
public:
    int longestOnes(vector<int>& nums, int k) {
        int size=0,len=0;
        for(int left=-1,right=0;right<nums.size();right++){
            if(nums[right]==0) size++;//进窗口
            if(size<=k) len=max(len,right-left);//判断和更新结果
            while(size>k)
                if(nums[++left]==0) size--;//出窗口
            }
        return len;
    }
};

时间复杂度:O(N)。空间复杂度:O(1)。

相关推荐
木头程序员2 分钟前
前端(包含HTML/JavaScript/DOM/BOM/jQuery)基础-暴力复习篇
开发语言·前端·javascript·ecmascript·es6·jquery·html5
Jayden_Ruan7 分钟前
C++分解质因数
数据结构·c++·算法
Data_agent13 分钟前
Cocbuy 模式淘宝 / 1688 代购系统(欧美市场)搭建指南
开发语言·python
lsx20240622 分钟前
《Foundation 下拉菜单》
开发语言
期待のcode26 分钟前
认识Java虚拟机
java·开发语言·jvm
微露清风29 分钟前
系统性学习C++-第二十讲-哈希表实现
c++·学习·散列表
raining_peidx29 分钟前
xxljob源码
java·开发语言
肥猪猪爸30 分钟前
双重检查锁(DCL)与 volatile 的关键作用
java·开发语言·单例模式
yaoxin52112338 分钟前
289. Java Stream API - 从字符串的字符创建 Stream
java·开发语言
清 澜43 分钟前
c++高频知识点总结 第 1 章:语言基础与预处理
c++·人工智能·面试