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

相关推荐
R1nG8632 小时前
CANN资源泄漏检测工具源码深度解读 实战设备内存泄漏排查
数据库·算法·cann
_OP_CHEN3 小时前
【算法基础篇】(五十六)容斥原理指南:从集合计数到算法实战,解决组合数学的 “重叠难题”!
算法·蓝桥杯·c/c++·组合数学·容斥原理·算法竞赛·acm/icpc
TracyCoder1233 小时前
LeetCode Hot100(27/100)——94. 二叉树的中序遍历
算法·leetcode
九.九3 小时前
CANN HCOMM 底层机制深度解析:集合通信算法实现、RoCE 网络协议栈优化与多级同步原语
网络·网络协议·算法
C++ 老炮儿的技术栈3 小时前
Qt Creator中不写代如何设置 QLabel的颜色
c语言·开发语言·c++·qt·算法
子春一3 小时前
Flutter for OpenHarmony:构建一个 Flutter 数字消消乐游戏,深入解析网格状态管理、合并算法与重力系统
算法·flutter·游戏
草履虫建模9 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq12 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq12 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq12 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习