leetcode_485. 最大连续 1 的个数

举报
悲恋花丶无心之人 发表于 2021/02/21 01:03:23 2021/02/21
【摘要】 目录 一、题目内容 二、解题思路 三、代码 一、题目内容 给定一个二进制数组, 计算其中最大连续 1 的个数。 示例: 输入:[1,1,0,1,1,1] 输出:3 解释:开头的两位和最后的三位都是连续 1 ,所以最大连续 1 的个数是 3. 提示: 输入的数组只包含 0 和 1 。 输入数组的长度是正整数,且不超过 10,00...

目录

一、题目内容

二、解题思路

三、代码


一、题目内容

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

示例:

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

提示:

输入的数组只包含 0 和 1 。
输入数组的长度是正整数,且不超过 10,000。

二、解题思路

1.直接记录长度然后每次比较大小即可;

2.滑动窗口,每次增加窗口长度,直到为0则记录长度并比较当前最大的长度,然后重新从为1的地方开始记录长度,如此反复比较即可;

三、代码


  
  1. class Solution:
  2. def findMaxConsecutiveOnes1(self, nums: list) -> int:
  3. count = 0
  4. ans = 0
  5. for num in nums:
  6. if num == 1:
  7. count += 1
  8. ans = max(ans, count)
  9. else:
  10. count = 0
  11. return ans
  12. def findMaxConsecutiveOnes2(self, nums: list) -> int:
  13. left, right = 0, 0
  14. ans = 0
  15. while right < len(nums):
  16. if nums[right] == 1:
  17. right += 1
  18. else:
  19. ans = max(ans, right - left)
  20. right += 1
  21. left = right
  22. ans = max(ans, right - left)
  23. return ans
  24. if __name__ == '__main__':
  25. s = Solution()
  26. nums = [1, 1, 0, 1, 1, 1]
  27. ans1 = s.findMaxConsecutiveOnes1(nums)
  28. print(ans1)
  29. ans2 = s.findMaxConsecutiveOnes2(nums)
  30. print(ans2)

文章来源: blog.csdn.net,作者:悲恋花丶无心之人,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/qq_36556893/article/details/113843760

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。