题目:
输入一个整型数组,数据元素有正数也有负数,求元素组合成连续子数组之和最大的子数组,要求时间复杂度为O(n)。...例如:
输入的数组为1, -2, 3, 10, -4, 7, 2, -5,最大和的连续子数组为3, 10, -4, 7, 2,其最大和为18。...由于本题在网络中广为流传,本题也顺利成为2006年程序员面试题中经典中的经典。
分析:
如果不考虑时间复杂度,我们可以枚举出所有子数组并求出他们的和。...不过非常遗憾的是,由于长度为n的数组有O(n2)个子数组(即:n + n-1 + ... + 1=n(n+1)/2);而且求一个长度为n的数组的和的时间复杂度为O(n)。...源码
参考推荐:
子数组的最大和[算法]
微软、Google等面试题