题目:
给定一个二进制数组 nums , 计算其中最大连续 1 的个数。
输入:nums = [1,1,0,1,1,1]
输出:3
解释:开头的两位和最后的三位都是连续 1 ,所以最大连续 1 的个数是 3.
能否写出:能写出来
时间:大概20分钟
思路:一开始根据nums[i] == 1
判断,答案错误,发现判断最后因没0直接跳过,思路就在循环里打转,后面跳出来,在遍历结束去比较更新,就一次成功了。
class Solution { public int findMaxConsecutiveOnes(int[] nums) { int count = 0; int result = 0; for (int i = 0; i < nums.length; i++) { if (nums[i] == 1) { count++; continue; } result = result = Math.max(count,result); count = 0; } result = Math.max(count,result); return result; } }
时间复杂度:O(n)
空间复杂度:O(1)
第二天修改后
初始化计数器 count = 0 和最大连续1的个数 result= 0。
遍历二进制数组:
如果当前元素为1,则将计数器 count 加1。
如果当前元素为0,则将计数器 count 置为0。
更新最大连续1的个数 result ,取 result 和 count 中的较大值。
返回最大连续1的个数 result 。
class Solution { public int findMaxConsecutiveOnes(int[] nums) { int count = 0; int result = 0; for (int num : nums) { if (num == 1) { count++; } else { count = 0; } result= Math.max(result, count); } return result; } }