• 算法总结之 未排序正数数组中累加和为给定值的最长子数组长度


    例如  arr=[1,2,1,1,1]   k=3

    累加和为 3的最长子数组为[1,1,1]   所以结果为3

     思路方法:

      两个指针 left  和right   初始值都是0  都在左边

       sum 代表 子数组 left.....right的和

       len 一直记录累加和为k的所有子数组中最大子数组的长度

      

      根据 sum与k的比较结果决定  left 跟 right 哪一个移动!!!!

    package TT;
    
    public class Test70 {
    
        public static int getMaxLength(int[] arr, int k){
            if(arr==null || arr.length==0 || k<0){
                return 0;
            }
            
            int left =0;
            int right = 0;
            int sum = arr[0];
            int len = 0;
            while(right < arr.length){
                
                if(sum ==k){
                    len = Math.max(len, right-left+1);
                    sum -= arr[left];
    left++; }
    else if(sum <k) { right++; if(right== arr.length){ break; } sum +=arr[right]; }else { sum -= arr[left];
    left++; } }
    return len; } public static void main(String[] args){ int[] arr = new int[5]; arr[0]=1; arr[1]=2; arr[2]=1; arr[3]=1; arr[4]=1; int x = getMaxLength(arr,3); System.out.println(x); } }

    结果:

  • 相关阅读:
    mysql 日志
    mysql 事务中的锁
    mysql 事务的日志
    mysql 核心事务特性
    mysql 断电导致表打不开解决方案
    mysql 数据库逻辑升级
    mysql innodb存储引擎的表空间
    IDEA常用代码模板
    springcloud-GateWay常用的Predicate
    springcloud-GateWay配置动态路由
  • 原文地址:https://www.cnblogs.com/toov5/p/7488792.html
Copyright © 2020-2023  润新知