基础数组-最大连续1的个数

题目描述

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

分析

可以使用一个简单的线性扫描算法,遍历数组并计算当前连续的 1 的数量,同时记录最大连续 1 的数量

代码

python 复制代码
class Solution:
    def findMaxConsecutiveOnes(self, nums: List[int]) -> int:
        """
        计算二进制数组中最大连续1的个数
        :params: nums:          - 二进制数组
        :return int:            - 最大连续1的个数
        """
        max_count, current_count = 0, 0

        for num in nums:
            if num == 1:
                # 当前连续1的个数
                current_count += 1
            else:
                # 更新当前位置最大连续1的个数
                max_count = max(max_count, current_count)
                # 重置当前连续1的个数
                current_count = 0
        # 最后再更新一次最大值,以防数组以1结尾
        max_count = max(max_count, current_count)
        return max_count

总结

这个问题涉及到简单的线性扫描算法,通过一次遍历即可解决。时间复杂度为 O(n),空间复杂度为 O(1)。这个算法的关键在于维护两个计数器,一个记录当前连续 1 的数量,另一个记录最大连续 1 的数量。在遍历过程中不断更新和比较这两个计数器,即可得到结果。

相关推荐
椰羊~王小美15 小时前
随机数概念及算法
算法
阿Y加油吧15 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
不要秃头的小孩16 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
We་ct16 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣17 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
hipolymers17 小时前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
workflower19 小时前
机器人应用-楼宇室内巡逻
大数据·人工智能·算法·microsoft·机器人·动态规划·享元模式
ZPC821019 小时前
fanuc 机器人通过PR寄存器实现轨迹控制
人工智能·算法·计算机视觉·机器人
py有趣19 小时前
力扣热门100题之编辑距离
数据结构·算法·leetcode