题目描述:最大子序和
给定一个序列(至少含有 1 个数),从该序列中寻找一个连续的子序列,使得子序列的和最大。
例如,给定序列 [-2,1,-3,4,-1,2,1,-5,4],
连续子序列 [4,-1,2,1] 的和最大,为 6。
解题思路一:动态规划
求和,然后判断和是否小于0,因为只要前面的和小于0,那么后面的数加上前面的和就一定比自身小,所以又重新求和,并和之前的最大子序和比较,取最大值。
public int maxSubArray(int[] nums) {
int max = nums[0];
int[] dp = new int[nums.length];
dp[0] = nums[0];
/**
* max:指的是i-1次循环后的最大值 如果dp[i-1]为正,则最大值为dp[i]
*
*/
for (int i = 1; i < nums.length; i++) {
dp[i] = nums[i] + (dp[i - 1] > 0 ? dp[i - 1] : 0);
max = Math.max(max, dp[i]);
}
return max;
}
注意一下:如果数组中都是负数,那么最大值就是数组中某个最大的数。