剑指offer 数组最大连续子序列的和 Java

求数组的最大连续子序列和

1.数组长度至少是1:

  1. 当数组长度1 直接返回数组0元素
  2. 当i=1时 cur与max都为0元素 从1开始 当cur+array[1]>array[1]的时候(arr[0]+array[1]>array[1])cur为两个数的和 否则cur从1元素重新开始 记录当前最优 即子数组{array[0],array[1]}的最大子数组长度。
  3. i++ 遵循上述规则。
public class Solution {
    public int FindGreatestSumOfSubArray(int[] array) {
        if(array.length==1)
            return array[0];
        int max=array[0];
        int cur=array[0];
        for(int i=1;i<array.length;i++){
           cur+=array[i];
           cur=cur<array[i]?array[i]:cur;
            max=Math.max(cur,max);
        }
     return max; 
    }
}

2.当要求子数组最小长度是2的时候

  1. 要求数组长度是2与1类似 但是需要用一个长度计数的变量
  2. 当长度>=2 就记录一下局部max值
public static int FindGreatestSumOfSubArray(int[] array) {
        int max=Integer.MIN_VALUE;
        int cur=array[0];
        int count=1;
        for(int i=1;i<array.length;i++){
           cur+=array[i];
           count++;
            if(count>1){
                max=Math.max(cur,max);
            }
          if(cur<array[i]){
              cur=array[i];
              count=1;
          }

        }
     return max;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值