题目:给定一个二进制数组, 计算其中最大连续1的个数。
示例 1:
输入: [1,1,0,1,1,1]
输出: 3
解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.
注意:
输入的数组只包含 0 和1。
输入数组的长度是正整数,且不超过 10,000。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/max-consecutive-ones
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
public int findMaxConsecutiveOnes(int[] nums) {
if(nums==null || nums.length==0){
return 0;
}
int len = nums.length;
int i=0;
int cnt = 0;//连续1计数
int temp = 0;//存储当前最大连续数
int cntBe = 0;
while(i<len){
if(nums[i]==0){//如果遇到0,计数器置为0
cntBe = cnt;//并去记录计数器清0这一变化
cnt = 0;
}else if(nums[i]==1){//如果是连续1,计数器加1
cnt++;
}
if(cntBe!=0 && cnt==0){//表示清零这一动作,当清零时,进行最大值分配
temp = temp < cntBe ? cntBe:temp;
}
i++;
}
temp = temp < cnt ? cnt:temp;
return temp;
//统计连续1的个数的方法
}
}