码迷,mamicode.com
首页 > 编程语言 > 详细

剑指Offer对答如流系列 - 连续子数组的最大和

时间:2020-01-31 20:31:32      阅读:63      评论:0      收藏:0      [点我收藏+]

标签:put   遍历   max   http   ffffff   题解   alt   gre   面试题   

面试题42:连续子数组的最大和

题目描述

输入一个整型数组,数组里有正数也有负数。数组中一个或连续的多个整/数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)。

问题分析

输入数组{1、-2、10、-4、7、2、-5}
技术图片

很容易看出从第一个数字开始累加,若走到某一个数字时,前面的累加和为负数,说明不能继续累加了。比如1 和 -2累加后值为-1,后面的数字加上-1反而变小了,应舍弃。要从接下来的数字重新开始累加。注意在累加过程中,将每次累加和的最大值记录下来,遍历完成后,返回该数字。

问题解答

  // 标识是否是无效输入
    boolean InvalidInput = false;
    public int FindGreatestSumOfSubArray(int[] array) {
        if(array==null || array.length<=0){
            InvalidInput = true;
            return 0;
        }
        InvalidInput = false;
        int sum=array[0];
        int maxSum=array[0];
        
        for(int i=1;i<array.length;i++){
            if(sum<0) {
                sum = array[i];
            } else {
                sum += array[i];
            }
            if(sum>maxSum) {
                maxSum=sum;
            }
        }
        return maxSum;
    }

剑指Offer对答如流系列 - 连续子数组的最大和

标签:put   遍历   max   http   ffffff   题解   alt   gre   面试题   

原文地址:https://www.cnblogs.com/JefferyChenXiao/p/12246457.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!