Leetcode485:最大连续1的个数
题目描述
示例 1:
输入: [1,1,0,1,1,1]
输出: 3
解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.
注意:
输入的数组只包含 0 和1。
输入数组的长度是正整数,且不超过 10,000。
解法一:基于sort的暴力法
class Solution {
public:
int findMaxConsecutiveOnes(vector<int>& nums) {
int flag = 0;
vector<int> max;
for (int i = 0; i<nums.size(); i++)
{
if (nums[i] == 1)
{
flag++;
}
else if (nums[i] == 0)
{
max.push_back(flag);
flag = 0;
}
}
max.push_back(flag);
sort(max.begin(), max.end());
return max[max.size() - 1];
}
};
解法二:简洁方法
class Solution {
public:
int findMaxConsecutiveOnes(vector<int>& nums) {
int max = 0, num = 0;
for (int i = 0; i<nums.size(); i++)
{
if (nums[i] == 1)
num++;
else
num = 0;
max = max>num ? max:num;
}
return max;
}
};