基础数组-最大连续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 的数量。在遍历过程中不断更新和比较这两个计数器,即可得到结果。

相关推荐
qystca23 分钟前
蓝桥云客--回文数组
算法
每次的天空24 分钟前
Android学习总结之算法篇五(字符串)
android·学习·算法
Fantasydg1 小时前
DAY 37 leetcode 454--哈希表.四数相加
算法·leetcode·散列表
前端 贾公子1 小时前
LeetCode 2442:统计反转后的不同整数数量
算法·leetcode·职场和发展
lmy201211081 小时前
GESP:2025-3月等级8-T1-上学
c++·算法·图论·dijkstra
珊瑚里的鱼2 小时前
第五讲(下)| string类的模拟实现
开发语言·c++·笔记·程序人生·算法·visualstudio·visual studio
工一木子2 小时前
大厂算法面试 7 天冲刺:第6天-树与图深度剖析——高频算法面试题 & Java 实战
java·算法·面试
查理零世2 小时前
【蓝桥杯速成】日期问题(填空题) + 真题讲解 python
python·算法·蓝桥杯
杰克逊的日记2 小时前
大语言模型应用和训练(人工智能)
人工智能·算法·语言模型
振鹏Dong3 小时前
字符串——面试考察高频算法题
java·数据结构·算法