题目
输入一个整型数组,数组里有正数也有负数。数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为 O(n)
思路
动态规划
状态定义:dp[i]表示以i结尾的连续子数组的最大和。所以最终要求dp[n-1]
状态转移方程:dp[i] = max(array[i], dp[i-1]+array[i])
解释:如果当前元素为整数,并且dp[i-1]为负数,那么当然结果就是只选当前元素
代码
public class Solution {
public int FindGreatestSumOfSubArray(int[] array) {
if (array.length == 0) return 0;
int ret = Integer.MIN_VALUE;;
int crt = 0;
for (int i=0; i<array.length; i++) {
if (crt >= 0) crt += array[i];
else crt = array[i];
if (crt > ret) ret = crt;
}
return ret;
}
}