给定一个二进制数组, 计算其中最大连续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
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
分析:
遇到0,更新累加的每一段最大值,返回 最后一个最大值和最后一段sum中的一个。
或者使用快慢指针。
解答:
class Solution {
public:
int findMaxConsecutiveOnes(vector<int>& nums) {
int sum = 0;
int max = 0;
for(int i=0;i<nums.size();i++){
if(nums[i]==0){
if(sum>max){
max = sum;
}
sum = 0;
}
sum+=nums[i];
}
return max>sum?max:sum;
}
};