【每日一题】LeetCode 485.最大连续1的个数 (数组、滑动窗口、双指针)

【每日一题】LeetCode 485.最大连续1的个数(数组、滑动窗口、双指针)

题目描述

给定一个二进制数组 nums,我们需要计算其中最大连续 1 的个数。

思路分析

这个问题可以通过一次遍历来解决。我们使用两个指针 leftright 来表示当前考虑的子数组的边界。初始时,left 指向数组的开始,right 也指向数组的开始。我们逐步移动 right 指针,直到遇到一个 0。每次遇到 0,我们就更新 left 指针的位置为 right 的位置,这样我们就得到了一个连续的 1 的序列。我们记录下这个序列的长度,并与之前记录的最大长度进行比较,更新最大长度。最后,返回最大长度即可。

输入示例

  1. 示例 1:

    • 输入:nums = [1,1,0,1,1,1]
    • 输出:3
    • 解释:开头的两位和最后的三位都是连续的 1,所以最大连续 1 的个数是 3
  2. 示例 2:

    • 输入:nums = [1,0,1,1,0,1]
    • 输出:2

代码实现

java 复制代码
class Solution {
    public int findMaxConsecutiveOnes(int[] nums) {
        // 初始化左右指针和结果变量
        int right = 0;
        int left = -1; // 将left初始化为-1,方便处理边界情况
        int res = 0; // 用于记录最大连续1的长度

        // 遍历数组
        while (right < nums.length) {
            // 如果当前元素是0,更新left指针
            if (nums[right] == 0) {
                left = right;
            } else {
                // 如果当前元素是1,更新最大长度
                res = Math.max(res, right - left);
            }
            // 移动right指针
            right++;
        }
        // 返回最大连续1的长度
        return res;
    }
}
相关推荐
唐梓航-求职中10 小时前
编程大师-技术-算法-leetcode-355. 设计推特
算法·leetcode·面试
biyezuopinvip10 小时前
基于Spring Boot的企业网盘的设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·企业网盘的设计与实现
Hx_Ma1610 小时前
SSM搭建(三)Spring整合SpringMVC框架
java·后端·spring
无风听海10 小时前
.NET10之ASP.NET Core的Filter管线
java·asp.net·.net
少许极端10 小时前
算法奇妙屋(二十八)-递归、回溯与剪枝的综合问题 1
java·算法·深度优先·剪枝·回溯·递归
仰泳的熊猫10 小时前
题目1453:蓝桥杯历届试题-翻硬币
数据结构·c++·算法·蓝桥杯
唐梓航-求职中10 小时前
技术-算法-leetcode-1606. 找到处理最多请求的服务器(易懂版)
服务器·算法·leetcode
Boop_wu10 小时前
简单介绍 JSON
java·开发语言
啊阿狸不会拉杆10 小时前
《机器学习导论》第 10 章-线性判别式
人工智能·python·算法·机器学习·numpy·lda·线性判别式
会叫的恐龙10 小时前
C++ 核心知识点汇总(第11日)(排序算法)
c++·算法·排序算法