/*
给定一个二进制数组, 计算其中最大连续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
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
*/
1
2
3
4
5
6
7
8
9
10
11
12
13
int findMaxConsecutiveOnes(int* nums, int numsSize)
{
int i = 0;
int ind_front = 0;
int ind_tail = 0;
int ret_val = 0;
for(i=0;i<numsSize;i++)
{
if(nums[ind_front]==0)
{
ind_front++;
ind_tail++;
}
else
{
if(nums[ind_tail]==1)
{
ind_tail++;
}
else
{
ret_val = (ret_val>=(ind_tail-ind_front)) ? ret_val :
(ind_tail-ind_front);
ind_tail++;
ind_front=ind_tail;
}
}
}
ret_val = (ret_val>=(ind_tail-ind_front)) ? ret_val : (ind_tail-
ind_front);
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
评论0