【优选算法】11----最大连续1的个数|||

---------------------------------------begin---------------------------------------

题目解析:

讲解算法原理:

这道题目可以使用滑动窗口算法来解决。滑动窗口的核心思想是通过维护一个窗口,使得窗口内的

0的个数不超过k,然后不断移动窗口的左右边界来找到最长的连续1子数组。

通过滑动窗口算法,我们可以高效地解决这个问题。滑动窗口算法的关键在于维护一个满足条件的

窗口,并通过移动窗口的边界来找到最优解。在这道题目中,我们通过维护一个窗口使得窗口内的

0的个数不超过k,从而找到了最长的连续1子数组。

编写代码:

cpp 复制代码
class Solution {
public:
    int longestOnes(vector<int>& nums, int k) {
        int ret=0;
        int n=nums.size();
        for(int right=0,left=0,zero=0;right<n;right++)
        {
            if(nums[right]==0)
            {
                zero++;
            }
            while(zero>k)
            {
                if(nums[left++]==0)
                {
                    zero--;
                }
            }
            ret=max(ret,right-left+1);
        }
        return ret;
    }
};

有兴趣的铁子可以参照我的思路来做一遍哦~

题目直达--->

1004. 最大连续1的个数 III - 力扣(LeetCode)

-------------------------------------------end-------------------------------------

相关推荐
熊峰峰7 分钟前
数据结构第八节:红黑树(初阶)
开发语言·数据结构·c++·算法
梅茜Mercy17 分钟前
C++:入门详解(关于C与C++基本差别)
java·c语言·c++
f狐0狸x1 小时前
【蓝桥杯每日一题】3.8
数据结构·c++·算法·蓝桥杯
牵牛老人1 小时前
C++设计模式-工厂模式:从原理、适用场景、使用方法,常见问题和解决方案深度解析
开发语言·c++·设计模式
阿巴~阿巴~1 小时前
动态规划填表技巧:固定最后一个数 vs 固定倒数第二个数
c++·算法·动态规划
我感觉。1 小时前
【机器学习chp12】半监督学习(自我训练+协同训练多视角学习+生成模型+半监督SVM+基于图的半监督算法+半监督聚类)
人工智能·算法·机器学习·半监督学习
h39741 小时前
Windows软件插件-视频渲染器
c++·windows·音视频
浊酒南街5 小时前
XGBClassifiler函数介绍
算法·机器学习·xgb
mlxg999995 小时前
hom_mat2d_to_affine_par 的c#实现
算法·计算机视觉·c#
讨厌下雨的天空8 小时前
C++之list
开发语言·c++·list