题目描述:
给定一个二进制数组, 计算其中最大连续 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)