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

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

例如  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); } }

结果:

 

posted @ 2017-09-07 11:26 toov5 阅读( ...) 评论( ...) 编辑 收藏
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值