leetcode 1493 删掉一个元素以后全为1的最长子数组

一、题目描述

二、解题思路

整体思路:

由于子数组具有连续性,且在模拟的过程中可以做到双指针不回退,所以可以用"滑动窗口"的思想来解决这个问题。

具体思路:

(1)首先进行边界处理:

<1>如果向量为空,直接返回0;

<2>如果向量中的元素均为1,只能删去一个1,所有返回sum-1;

(2)count用于记录窗口中0的数量,len用于记录子数组的最大长度,滑动窗口要素如下:

<1>进窗口:如果0进入窗口,则count++

//进窗口

if(nums[right]==0) count++;

<2>出窗口:如果count的数量大于1,则count--

//判断

while(count>1) {

//出窗口

if(nums[left++]==0) count--;

}

<3>更新:len用于记录子数组的最大长度

//更新

len=max(len,right-left+1-count);

三、代码实现

cpp 复制代码
class Solution {
public:
    int longestSubarray(vector<int>& nums) {
        //边界处理
        //为空
        if(nums.empty()) return 0;
        //全为1
        int sum=0;
        for(int i=0;i!=nums.size();i++){
            if(nums[i]==1)
                sum++;
        }
        if(sum==nums.size()) return sum-1;

        //滑动窗口
        int count=0,len=0;
        for(int left=0,right=0;right!=nums.size();right++){
            //进窗口
            if(nums[right]==0) count++;
            //判断
            while(count>1) {
                //出窗口
                if(nums[left++]==0) count--;
            }
            //更新
            len=max(len,right-left+1-count);
        }
        return len;
    }
};
相关推荐
kaikaile199511 分钟前
基于 MATLAB 的室内三维定位
算法
雾岛听蓝14 分钟前
C++ 入门核心知识点(从 C 过渡到 C++ 基础)
开发语言·c++·经验分享·visual studio
AGI前沿25 分钟前
AdamW的继任者?AdamHD让LLM训练提速15%,性能提升4.7%,显存再省30%
人工智能·算法·语言模型·aigc
Tan_Ying_Y27 分钟前
什么是垃圾回收算法 他的底层原理是什么?
算法
Xの哲學40 分钟前
Linux 分区表深度技术剖析
linux·网络·算法·架构·边缘计算
写写闲篇儿1 小时前
经典算法题剖析之传递信息(三)
算法
上不如老下不如小1 小时前
2025年第七届全国高校计算机能力挑战赛初赛 Python组 编程题汇总
开发语言·python·算法
xlq223221 小时前
19.模版进阶(上)
c++
yuuki2332331 小时前
【C++】初识C++基础
c语言·c++·后端
小年糕是糕手1 小时前
【C++】类和对象(二) -- 构造函数、析构函数
java·c语言·开发语言·数据结构·c++·算法·leetcode