zoukankan      html  css  js  c++  java
  • Java程序设计:最大连续1的个数(LeetCode:485)

    题目:给定一个二进制数组, 计算其中最大连续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
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    class Solution {
    public int findMaxConsecutiveOnes(int[] nums) {
    if(nums==null || nums.length==0){
    return 0;
    }
    int len = nums.length;
    int i=0;
    int cnt = 0;//连续1计数
    int temp = 0;//存储当前最大连续数
    int cntBe = 0;

    while(i<len){
    if(nums[i]==0){//如果遇到0,计数器置为0
    cntBe = cnt;//并去记录计数器清0这一变化
    cnt = 0;
    }else if(nums[i]==1){//如果是连续1,计数器加1
    cnt++;
    }

    if(cntBe!=0 && cnt==0){//表示清零这一动作,当清零时,进行最大值分配
    temp = temp < cntBe ? cntBe:temp;
    }
    i++;
    }
    temp = temp < cnt ? cnt:temp;
    return temp;
    //统计连续1的个数的方法

    }
    }
  • 相关阅读:
    C++中unique函数的用法总结
    洛谷P1039侦探推理题解
    洛谷P1040 加分二叉树题解
    洛谷P1038 神经网络题解
    emmm
    biiset用法
    浅谈接口与抽象类的区别
    递归调用——数学观点看递归
    反转字符串
    SQL 时间戳转DateTime类型
  • 原文地址:https://www.cnblogs.com/Yi-ling/p/14074270.html
Copyright © 2011-2022 走看看