Skip to main content

最大子序和

题目

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

提示:
  • 1 <= nums.length <= 10⁵
  • -10⁴ <= nums[i] <= 10⁴
示例

输入: nums = [-2, 1, -3, 4, -1, 2, 1, -5, 4]

输出: 6

解释: 连续子数组 [4, -1, 2, 1] 的和最大, 为 6.

题解

Kadane 算法(Kadane's algorithm)是一种用于解决最大子数组和问题的动态规划算法.

/**
* @param {number[]} nums
* @return {number}
*/
var maxSubArray = function (nums) {
let maxEndingHere = nums[0]
let maxSoFar = nums[0]

for (let i = 1; i < nums.length; i++) {
maxEndingHere = Math.max(nums[i], maxEndingHere + nums[i])
maxSoFar = Math.max(maxSoFar, maxEndingHere)
}

return maxSoFar
}