题目链接
https://leetcode-cn.com/problems/maximum-subarray/
一、题目
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
示例:
输入: [-2,1,-3,4,-1,2,1,-5,4]
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。
二、分析和代码
1.分析
求最大子序和,动态规划是比较好的
1.最大连续子序列和:
dp[i] = max{ A[i] , dp[i-1] + A[i] };
边界:dp[0] = A[0];
2.代码
【1】普通方法
int maxSubArray(int* nums, int numsSize){
int maxn=nums[0];
int sum;
for(int i=0;i<numsSize;i++){
sum=0;
for(int j=i;j<numsSize;j++){
sum=sum+nums[j];
if(sum>maxn) maxn=sum;
else continue;
}
}
return maxn;
}
【2】动态规划
int maxSubArray(int* nums, int numsSize){
int max = nums[0];
int *res = (int *)malloc(numsSize * sizeof(int));
res[0] = nums[0];
for (int i = 1; i < numsSize; ++i) {
if (res[i - 1] <= 0) { // 数组中以第 i - 1 个数字结尾的子数组的最大和不大于 0 ,从第 i 个数字开始寻找
res[i] = nums[i];
} else { // 数组中以第 i - 1 个数字结尾的子数组的最大和大于 0 ,则与第 i 个数字累加得以第 i 个数字结尾的子数组的和
res[i] = res[i - 1] + nums[i];
}
max = max > res[i] ? max : res[i];
}
return max;
}