题目描述:
给定一个二进制数组, 计算其中最大连续1的个数。
示例 1:
输入: [1,1,0,1,1,1]
输出: 3
解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.
注意:
输入的数组只包含 0 和1。
输入数组的长度是正整数,且不超过 10,000。
双指针法:
class Solution {
public int findMaxConsecutiveOnes(int[] nums) {
if(nums==null||nums.length==0)
return 0;
int start=0;
int end=0;
int max=0;
int length=0;
while(end<nums.length)
{
if(nums[start]!=1)
{
start++;
end=start;
length=0;
continue;
}
else{
if(nums[end]==1)
{
length++;
}
else
{
start=end+1;
end=start-1;
length=0;
}
}
max=Math.max(max,length);
end++;
}
return max;
}
}