Given a binary array, find the maximum number of consecutive 1s in this array.
Example 1:
Input: [1,1,0,1,1,1]
Output: 3
Explanation: The first two digits or the last three digits are consecutive 1s.
The maximum number of consecutive 1s is 3.
Note:
The input array will only contain 0 and 1.
The length of input array is a positive integer and will not exceed 10,000
Solution 1 (10ms):
class Solution {
public int findMaxConsecutiveOnes(int[] nums) {
int maximum = 0, count = 0;
for(int num:nums){
if(num != 0){
count++;
}
else{
count = 0;
}
maximum = Math.max(maximum, count);
}
return maximum;
}
}
Solution2 (8ms):
class Solution {
public int findMaxConsecutiveOnes(int[] nums) {
int Max = 0, cnt = 0;
for(int n:nums)
{
cnt = (cnt + 1) *n;
Max = Math.max(Max, cnt);
}
return Max;
}
}