时间:2020-06-25
题目地址:https://leetcode-cn.com/problems/max-consecutive-ones/
题目难度:Easy
题目描述:
给定一个二进制数组, 计算其中最大连续1的个数。
示例 1:
输入: [1,1,0,1,1,1]
输出: 3
解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.
注意:
输入的数组只包含 0 和1。
输入数组的长度是正整数,且不超过 10,000。
思路1:暴力遍历
代码段1:通过
class Solution:
def findMaxConsecutiveOnes(self, nums: List[int]) -> int:
temp, result = 0, 0
for i in nums:
if i == 1:
temp += 1
else:
temp = 0
result = max(temp, result)
return result
思路2:切片
代码段2:通过
class Solution:
def findMaxConsecutiveOnes(self, nums: List[int]) -> int:
return max(map(len, ''.join(map(str, nums)).split('0')))