给定一个二进制数组, 计算其中最大连续1的个数。
示例 1:
输入: [1,1,0,1,1,1]
输出: 3
解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.
注意:
输入的数组只包含 0 和1。
输入数组的长度是正整数,且不超过 10,000。
我的代码:
class Solution:
def findMaxConsecutiveOnes(self, nums: List[int]) -> int:
if 1 not in nums:
return 0
s = ''.join(str(i) for i in nums)
num = s.split('0')
num = list(filter(None, num))
numbers = list(map(int, num))
return len(str(max(numbers)))
真的好慢
找到了一个好一点的写法,要快很多
class Solution:
def findMaxConsecutiveOnes(self, nums: List[int]) -> int:
count = 0
totalCount = 0
for num in nums:
if num == 1:
count=count+1
else:
count = 0
if count>totalCount:
totalCount = count
return totalCount