美文网首页
leetcode - 53. 最大子序和

leetcode - 53. 最大子序和

作者: 恍若如梦hzpeng | 来源:发表于2020-06-02 15:22 被阅读0次

题目描述:

image.png

解法:动态规划

/**
 * @param {number[]} nums
 * @return {number}
 */
var maxSubArray = function(nums) {
    let max = nums[0];
    let dp = [];
    dp[0] = nums[0];
    for (let i = 1; i < nums.length; i++) {
        dp[i] = Math.max(dp[i - 1] + nums[i], nums[i]);
        max = Math.max(max, dp[i])
    }
    return max;
};

或者

/**
 * @param {number[]} nums
 * @return {number}
 */
var maxSubArray = function(nums) {
    let ans = nums[0];
    let sum = 0;
    for(let i = 0; i < nums.length; i++) {
        if (sum > 0) {
            sum += nums[i]
        } else {
            sum = nums[i]
        }
        ans = Math.max(ans, sum)
    }
    return ans;
}

相关文章

网友评论

      本文标题:leetcode - 53. 最大子序和

      本文链接:https://www.haomeiwen.com/subject/znvuzhtx.html