大厂面试题练习-具有最大和的连续子数组


题目:具有最大和的连续子数组

在给定的数组中找到具有最大和的连续子数组,并返回最大的和

示例

输入:[-2, 2, -1, 1, -3]
输出:2

答案

function maxSubArray(arr) {
  let ans = arr[0],
    sum = 0;
  for (let i = 0; i < arr.length; i++) {
    const item = arr[i];
    if (sum > 0) {
      sum += item;
    } else {
      sum = item;
    }
    ans = Math.max(sum, ans);
  }
  return ans;
}
console.log(maxSubArray([-2, -2, -1, -1, -3])); // -1
console.log(maxSubArray([-2, 2, 1, -1, -3])); // 3

文章作者: CassielLee
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 CassielLee !
评论
  目录