题目描述:

思路分析:
运用动态规划的思想,设动态规划列表 dp ,dp[i] 代表以元素 nums[i] 为结尾的连续子数组最大和。从第二个元素开始遍历原数组,如果dp[i-1]是大于0的,就说明当前元素加上之前的最大字数组和会更大,故dp[i]=dp[i-1]+nums[i],如果dp[i-1]是小与0的,说明此时以nums[i]结尾的最大字数组为dp[i]=nums[i],最后遍历dp数组就会的解。
代码:
java
class Solution {
public int maxSubArray(int[] nums) {
int n=nums.length;
int dp[] =new int[n];
dp[0]=nums[0];
for(int i=1;i<n;i++){
if(dp[i-1]>0){
dp[i]=dp[i-1]+nums[i];
}else{
dp[i]=nums[i];
}
}
int ans=-10000;
for(int i=0;i<n;i++){
ans=Math.max(dp[i],ans);
}
return ans;
}
}