【力扣】485.最大连续 1 的个数

简介: 【力扣】485.最大连续 1 的个数

485. 最大连续 1 的个数

题目描述

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

示例 1:

输入:nums = [1,1,0,1,1,1]

输出:3

解释:开头的两位和最后的三位都是连续 1 ,所以最大连续 1 的个数是 3.

示例 2:

输入:nums = [1,0,1,1,0,1]

输出:2

提示:

  • 1 <= nums.length <= 105
  • nums[i] 不是 0 就是 1.

解题方法

  • C 遍历取最大
// #define MAX(a, b) ((a) > (b) ? (a) : (b)) // 取最大值

int my_max(int a, int b) {
    if (a > b)
        return a;
    else
        return b;
}

int findMaxConsecutiveOnes(int* nums, int numsSize) {
    int max_cnt = 0, cnt = 0; // 定义最大计数变量,计数变量
    for (int i = 0; i < numsSize; i++) {
        if (nums[i] == 1) {
            cnt++; // 对 1 计数
        } else {
            max_cnt = my_max(max_cnt, cnt); // 存储最大 1 的个数
            cnt = 0;                        // 重新计数
        }
    }
    max_cnt = my_max(max_cnt, cnt);
    return max_cnt;
}

复杂度分析

时间复杂度为 O(n),其中 n 是数组的长度。

空间复杂度为 O(1)。




目录
打赏
0
1
1
0
10
分享
相关文章
Python新手常见问题一:列表、元组、集合、字典区别是什么?
本文针对Python编程新手常遇到的问题,详细阐述了列表(List)、元组(Tuple)、集合(Set)和字典(Dictionary)这四种数据结构的核心区别。列表是一种有序且可变的数据序列,允许元素重复;元组同样有序但不可变,其内容一旦创建就不能修改;集合是无序、不重复的元素集,强调唯一性,主要用于数学意义上的集合操作;而字典则是键值对的映射容器,其中键必须唯一,而值可以任意,它提供了一种通过键查找对应值的有效方式。通过对这些基本概念和特性的对比讲解,旨在帮助初学者更好地理解并运用这些数据类型来解决实际编程问题。
1502 1
|
9月前
|
LeetCode整数反转
解决LeetCode上的整数反转问题的几种方法,包括错误的方法和优化后的解决方案,以及如何避免反转后的整数超出32位有符号整数范围的问题。
98 1
NGINX环境下实现Web网站访问控制的实战指南
在NGINX中设置基于IP的访问控制可提升网站安全性。步骤包括安装NGINX、备份配置文件、编辑`/etc/nginx/sites-available/default`,添加`allow`和`deny`指令限制特定IP访问,如`allow 192.168.1.100; deny all;`,然后测试配置并重启服务。成功后,仅允许的IP能访问网站,否则会收到403错误。这为Web安全提供基础保障,还可扩展实现更多高级控制策略。【6月更文挑战第20天】
1044 3
软件测试的演变:从手动到自动化的旅程
本文深入探讨了软件测试领域从传统的手动测试实践,经过部分自动化,最终发展到全面自动化测试的过程。文章首先概述了手动测试的局限性,然后详细介绍了自动化测试的兴起及其带来的革命性变化,包括提高测试效率、确保测试一致性和扩展测试覆盖范围等方面。接着,通过具体案例分析,展示了自动化测试在实际应用中的效益,并讨论了实施自动化测试时面临的挑战与解决策略。最后,文章对自动化测试的未来趋势进行了展望,强调了持续集成/持续部署(CI/CD)和人工智能(AI)在测试自动化中的重要性。
自动化测试在敏捷开发中的应用:加速迭代,保障质量
【8月更文挑战第2天】自动化测试在敏捷开发中扮演着至关重要的角色。通过提升测试效率、提高测试覆盖率、及时反馈与修复等优势,自动化测试为敏捷开发团队提供了强大的支持。然而,在实施自动化测试的过程中也面临着一些挑战。通过选择合适的测试框架和工具、制定测试计划和策略、持续优化和维护等策略以及遵循最佳实践并克服挑战,我们可以充分发挥自动化测试在敏捷开发中的潜力,为软件质量的提升和快速迭代保驾护航。
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
103267 0
力扣经典150题第三十七题:矩阵置零
力扣经典150题第三十七题:矩阵置零
66 2
深入理解白盒测试:方法、工具与实践
【4月更文挑战第7天】 在软件开发的质量控制过程中,白盒测试是确保代码逻辑正确性的关键步骤。不同于黑盒测试关注于功能和系统的外部行为,白盒测试深入到程序内部,检验程序结构和内部逻辑的正确性。本文将探讨白盒测试的核心技术,包括控制流测试、数据流测试以及静态分析等方法,同时介绍当前流行的白盒测试工具,并讨论如何在实际项目中有效实施白盒测试。文章的目标是为软件测试工程师提供一份综合性指南,帮助他们更好地理解和应用白盒测试技术。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等