【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)。

相关推荐
wjs20248 分钟前
DOM CDATA
开发语言
Tingjct9 分钟前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
猷咪36 分钟前
C++基础
开发语言·c++
IT·小灰灰37 分钟前
30行PHP,利用硅基流动API,网页客服瞬间上线
开发语言·人工智能·aigc·php
快点好好学习吧39 分钟前
phpize 依赖 php-config 获取 PHP 信息的庖丁解牛
android·开发语言·php
秦老师Q39 分钟前
php入门教程(超详细,一篇就够了!!!)
开发语言·mysql·php·db
烟锁池塘柳040 分钟前
解决Google Scholar “We‘re sorry... but your computer or network may be sending automated queries.”的问题
开发语言
是誰萆微了承諾40 分钟前
php 对接deepseek
android·开发语言·php
CSDN_RTKLIB43 分钟前
WideCharToMultiByte与T2A
c++
2601_9498683644 分钟前
Flutter for OpenHarmony 电子合同签署App实战 - 已签合同实现
java·开发语言·flutter