[LeetCode][简单][数组] 485 最大连续1的个数

题目描述:
给定一个二进制数组, 计算其中最大连续 1 的个数。
示例:
输入:[1,1,0,1,1,1]
输出:3
解释:开头的两位和最后的三位都是连续 1 ,所以最大连续 1 的个数是 3.
提示:
输入的数组只包含 0 和 1 。
输入数组的长度是正整数,且不超过 10,000。

解题思路

1.对数组遍历一次,遍历是需要保存遇到的最后一个0的位置index
2.如果遍历到i位置的数字是0,那么更新index为当前位置i
3.如果遍历到i位置的数字是1,那么当前区间内共有i-index个连续的1;
4.记录遍历过程中所有连续的1的长度的最大值。

代码

代码中的index保存的是遍历到的最后一个0的位置,其默认值是-1。
python代码如下:

class Solution(object):
    def findMaxConsecutiveOnes(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        index = -1
        res = 0
        for i, num in enumerate(nums):
            if num == 0:
                index = i
            else:
                res = max(res, i - index)
        return res

时间复杂度:O(N)
空间复杂度:O(1)

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容