美文网首页
连续子数组的最大和

连续子数组的最大和

作者: 囧略囧 | 来源:发表于2020-02-17 10:47 被阅读0次

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

这道题目可以分解为一个相同的模式:

假设有一个数组int[] array = {1, -2, 3, 10, -4, 7, 2, -5},那么:

前1个数的最大和:只有一个数,明显为1,

前2个数的最大和:看第二个数加上前1个数是变大还是变小,即分析前1个数的最大和为正还是为负,若为负,则最大和为array[1], 否则为前1个数最大和加上array[1]。

前3个数的最大和:分析前2个数的最大和为正还是负,若为负,则最大和为array[2],否则为前2个数最大和加上array[2]。

……

……

最后很容易得到前n个数的最大和。

[table id=4 /]

public class Solution {
    public static int FindGreatestSumOfSubArray(int[] array) {
        //切勿忘记考虑健壮性
        if (array.length==0 || array==null) {
            return 0;
        }
        int sum = 0, Max = Integer.MIN_VALUE;
        for(int i = 0; i < array.length; i++) {
            if(sum <= 0)
                sum = array[i];
            else
                sum += array[i];
            if(sum > Max) 
                Max = sum;
        }
        return Max;
    }
}

相关文章

  • 动态规划

    1子序列的最大和 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最...

  • [剑指offer]刷题笔记

    连续子数组的最大和(常见✔) 最小的k个数 数组中出现次数超过一半的数字 数据流中的中位数(难♧) 连续子数组的最...

  • 连续子数组的最大和和子数组

    网上多见的是输出连续子数组的最大和,此代码还额外输出了最大和对应的子数组。代码如下:

  • 2022-02-26最大子数组的和

    给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组...

  • Swift刷算法:最大子数组和

    给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。子数组 ...

  • 53. 最大子序和

    题目链接: 53. 最大子序和 题目描述: 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最...

  • 连续子数组最大和

    二刷: 剑指思路,只需要遍历一遍

  • 连续子数组最大和

    思路:

  • 连续子数组最大和

    方法1:归纳法 方法2:动态规划

  • 连续子数组最大和

    描述:输入一个整型数组,数组里有正数也有负数。数组中一个或连续的多个整数组成一个子数组。求所有子数组的和的最大值。...

网友评论

      本文标题:连续子数组的最大和

      本文链接:https://www.haomeiwen.com/subject/aqkvqctx.html