【C++刷题】力扣-#485-最大连续1的个数

题目描述

给定一个二进制数组 nums,计算该数组中连续 1 的最大数量。

示例

示例 1

bash 复制代码
输入: nums = [1,1,0,1,1,1]
输出: 3
解释: 最长连续 1 的序列是 [1,1,1]。

示例 2

bash 复制代码
输入: nums = [1,0,1,1,1,1]
输出: 3
解释: 最长连续 1 的序列是 [1,1,1]。

题解

这个问题可以通过一次遍历来解决。

  1. 初始化计数器:设置变量 maxCount 来记录连续 1 的最大数量,以及 currentCount 来记录当前连续 1 的数量。
  2. 遍历数组:遍历整数数组 nums。
    ○ 如果当前元素是 1,则 currentCount 加 1。
    ○ 如果当前元素是 0,则重置 currentCount 为 0,并更新 maxCount(如果需要)。
  3. 更新最大值:每次 currentCount 增加后,都要检查是否需要更新 maxCount。
  4. 返回结果:遍历结束后,返回 maxCount。

代码实现

cpp 复制代码
int maxConsecutiveOnes(vector<int>& nums) {
    int maxCount = 0;
    int currentCount = 0;
    for (int num : nums) {
        if (num == 1) {
            currentCount++;
        } else {
            maxCount = max(maxCount, currentCount);
            currentCount = 0;
        }
    }
    return max(maxCount, currentCount); 
}

复杂度分析

● 时间复杂度:O(n),其中 n 是数组 nums 的长度。我们需要遍历一次数组。

● 空间复杂度:O(1),因为我们只使用了常数个额外变量。

这个算法的优势在于它只需要一次遍历即可找到连续 1 的最大数量,且不需要额外的存储空间。

相关推荐
70asunflower3 小时前
CUDA编程指南基础知识点总结(5)
c++·人工智能·cuda
Eward-an3 小时前
LeetCode 1980 题通关指南|3种解法拆解“找唯一未出现二进制串”问题,附Python最优解实现
python·算法·leetcode
程序员酥皮蛋4 小时前
hot 100 第四十题 40.二叉树的层序遍历
数据结构·算法·leetcode
木斯佳5 小时前
HarmonyOS 6实战:从爆款vlog探究鸿蒙智能体提取关键帧算法
算法·华为·harmonyos
Mr.朱鹏5 小时前
JVM-GC垃圾回收案例
java·jvm·spring boot·算法·spring·spring cloud·java-ee
WJSKad12356 小时前
【DepthPro】实战教程:单目深度估计算法详解与应用
算法
wzqllwy6 小时前
8 大经典排序算法(Java 实现):原理 + Demo + 核心分析
java·算法·排序算法
We་ct6 小时前
LeetCode 77. 组合:DFS回溯+剪枝,高效求解组合问题
开发语言·前端·算法·leetcode·typescript·深度优先·剪枝
重生之我是Java开发战士6 小时前
【递归、搜索与回溯】二叉树中的深度优先搜索:布尔二叉树,求根节点到叶节点数字之和,二叉树剪枝,验证二叉搜索树,第K小的元素,二叉树的所有路径
算法·深度优先·剪枝
篮l球场6 小时前
矩阵置零
算法