首页 > 其他 > 详细

53. 最大子序和

时间:2020-06-07 16:32:21      阅读:34      评论:0      收藏:0      [点我收藏+]

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

示例:

输入: [-2,1,-3,4,-1,2,1,-5,4],
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。

dp动态规划:

技术分享图片

 

 

解题题解:

int maxSubArray(int* nums, int numsSize){
    int *dp=(int *)malloc(sizeof(int)*numsSize);

    dp[0]=nums[0];

    int result=dp[0];
    for(int count=1;count<numsSize;count++)
    {
        dp[count]=0;
        if(dp[count-1]>0){
            dp[count]=nums[count]+dp[count-1];
        }
        else{
            dp[count]=nums[count];
        }
    }

    for(int count=0;count<numsSize;count++)
    {
        if(result<dp[count]){
            result=dp[count];
        }
    }

    return result;
}

  

 

53. 最大子序和

原文:https://www.cnblogs.com/longlyseul/p/13060959.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!