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

2025年- H109-Lc1493. 删掉一个元素以后全为 1 的最长子数组(双指针)--Java版

1.题目描述

在这里插入图片描述

2.思路

如果有元素之间有相对顺序关系的话,不建议使用hashmap
在这里插入图片描述

(1)不定长滑动窗口:
不定长滑动窗口主要分为三类:求最长子数组,求最短子数组,求子数组个数。
注:滑动窗口相当于在维护一个队列。右指针的移动可以视作入队,左指针的移动可以视作出队。
(2)删除后,子数组只有 1,也就是没有 0。那么删除之前呢?至多有一个 0。
(3)cnt = cnt - (1 - nums[left]);
如果将要移出窗口的 nums[left] 是 1,那么 1 - nums[left] 的结果是 0。cnt 不变(因为移出一个1对0的个数没有影响)。

如果将要移出窗口的 nums[left] 是 0,那么 1 - nums[left] 的结果是 1。cnt 减少 1(因为我们把一个0移出了窗口)。

所以,这行代码的作用是:当窗口移出一个 0 时,cnt 减一。

(4)当右指针 right 移动,元素进入窗口时:

执行 cnt = cnt + 1 - nums[right];

如果 nums[right] 是 1,那么 1 - nums[right] 的结果是 0。cnt 不变。

如果 nums[right] 是 0,那么 1 - nums[right] 的结果是 1。cnt 增加 1。

所以,这行代码的作用是:当窗口滑入一个 0 时,cnt 加一。

3.代码实现

class Solution {public int longestSubarray(int[] nums) {//1.左右指针都从0开始移动int left=0;int cnt=0;//存0的个数int res=0;for(int right=0;right<nums.length;right++){ //1-nums[right]:从左往右遍历记录0的个数。因为遇到1的时候:1-1=0;遇到0的时候为1-0=1;实现计数功能//1.右指针进入窗口。当窗口滑入一个 0 时,cnt 加一。cnt=cnt+1-nums[right];while(cnt>1)//如果0的个数大于1,退出循环{//窗口末尾元素(最左边的元素)出队,nums[left]离开窗口//当窗口移出一个 0 时,cnt 减一。cnt=cnt-(1-nums[left]);left++;}// 3. 更新答案,注意不是 right-left+1,因为我们要删掉一个数res=Math.max(res,right-left);} return res;}
}
http://www.xdnf.cn/news/1438165.html

相关文章:

  • 别再误会了!Redis 6.0 的多线程,和你想象的完全不一样
  • 从入门到实战:Linux sed命令全攻略,文本处理效率翻倍
  • 【机器学习深度学习】向量模型与重排序模型:RAG 的双引擎解析
  • 使用DataLoader加载本地数据 食物分类案例
  • GitHub Classroom:编程教育的高效协作方案
  • MySQL查询limit 0,100和limit 10000000,100有什么区别?
  • Shell编程从入门到实践:基础语法与正则表达式文本处理指南
  • 如何在部署模型前训练出完美的AI提示词
  • C# 中这几个主流的 ORM(对象关系映射器):Dapper、Entity Framework (EF) Core 和 EF 6
  • 11.《简单的路由重分布基础知识探秘》
  • 硬件:51单片机
  • 为什么需要锁——多线程的数据竞争是怎么引发错误的
  • 系统架构——过度设计
  • YOLOv8改进有效系列大全:从卷积到检测头的百种创新机制解析
  • 【C++上岸】C++常见面试题目--数据结构篇(第十七期)
  • 02-Media-2-ai_rtsp.py 人脸识别加网络画面RTSP推流演示
  • 51单片机(单片机基础,LED,数码管)
  • Spring Boot手写10万敏感词检查程序
  • UCIE Specification详解(十三)
  • C++ 条件变量,互斥锁
  • 【c++】多态+RTTI (运行时的类型识别信息)
  • 深度学习篇---DenseNet
  • 深入解析Linux进程概念与操作系统核心
  • 深度学习篇---SGD优化器
  • 「数据获取」《安徽建设统计年鉴》(2002-2007)(2004、2006缺失)(获取方式看绑定的资源)
  • spring boot驴友结伴游网站的设计与实现(代码+数据库+LW)
  • 使用Global Watersheds提取水文站控制区域(水文站上下游 流域水系等)
  • 【自记】Python 中 简化装饰器使用的便捷写法语法糖(Syntactic Sugar)示例
  • 复刻 Python 实现的小智语音客户端项目py-xiaozhi日记
  • 【算法笔记 day six】二分算法的第三部分