当前位置: 首页 > news >正文

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);

三、代码实现

class Solution {
public:int longestSubarray(vector<int>& nums) {//边界处理//为空if(nums.empty()) return 0;//全为1int 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;}
};

http://www.xdnf.cn/news/1359037.html

相关文章:

  • mybatis过渡到mybatis-plus过程中需要注意的地方
  • 《Distilling the Knowledge in a Neural Network》论文PDF分享, 2015 年,谷歌提出了 “知识蒸馏” 的概念
  • 06 - spring security角色和权限设置
  • vulnhub-billu_b0x靶机渗透
  • GPT-5国内免费体验
  • k8s下的网络通信之calico与调度
  • sqlite创建数据库,创建表,插入数据,查询数据的C++ demo
  • 最新sa-token的oauth2封装免密和密码登录
  • 【高等数学】第十章 重积分——第一节 二重积分的概念与性质
  • MinIO03-Linux安装
  • Docker安装RocketMQ
  • 征程 6X 常用工具介绍
  • AI大模型应用开发面试:深入解析技术点
  • 每日算法题【链表】:相交链表、环形链表、环形链表II
  • 鸿蒙中点击完成时延分析
  • LeetCode 42.接雨水
  • response对象的elapsed属性
  • Elasticsearch Ruby 客户端故障排查实战指南
  • Bright Data MCP:突破AI数据获取限制的革命性工具
  • 阿里云 OSS 前端直传实战:表单上传 + Policy 模式详解
  • GD32VW553-IOT 测评和vscode开发环境搭建
  • 硬件开发_基于物联网的宠物猫饲养系统
  • 互联网大厂Java面试模拟:核心技术点深度解析
  • 极验demo(float)(二)
  • 从字节码层面剖析以太坊智能合约创建原理
  • EXCEL实现复制后倒序粘贴
  • 从Android到鸿蒙:一场本应无缝的转型-优雅草卓伊凡
  • iptables 防火墙核心知识梳理(附实操指南)
  • 【文献阅读】Land degradation drivers of anthropogenic sand and dust storms
  • 《一次高并发场景下疑难Bug的深度排查与复盘》