Javascript算法最大子数组

Javascript算法最大子数组,第1张

Javascript算法最大子数组

最大= -2和= -2

循环arr [1] = 1:sum = max(-2 + 1,1)= 1,max = max(sum = 1,max = -2)= 1

最大= 1总和= 1

循环arr [2] =-3:sum = max(1 + -3,-3)= -2,max = max(sum = -2,max = 1)= 1

最大= 1总和= -2

循环arr [3] = 4:sum = max(-3 + 4,4)= 4,max = max(sum = 4,max = 1)= 4

最大值= 4和= 4

循环arr [4] =-1:sum = max(4 + -1,-1)= 3,max =(3,4)= 4

最大值= 4和= 3

循环arr [5] = 2:sum = max(3 + 2,2)= 5,max = max(5,4)= 5

因此迭代看起来像这样:

arr [-2,1,-3,4,-1,2,1,-5,4]  x,1,x,4、3、5、6、1、5的总和最大-2、1、1、4、4、5、6、6、6

这就像寻找累加和,丢弃负序列或在和为负时开始新序列一样,因为任何负序列都会对序列的总和产生负面影响。

并且,您使用max = Math.max(max,sum),(将max设置为更大的值,当前最大值或当前总和)来查找渐进总和中达到的最大值(为6)。
这也说明了所有负数的边缘情况,其中最大和为最大负数。

const givenArray = [-2, 1, -3, 4, -1, 2, 1, -5, 4];const getMax = arr => {  let sum = arr[0]; //-2  let max = arr[0]; //-2  for (let i = 1; i < arr.length; i++) {    sum = Math.max(sum + arr[i], arr[i]);    max = Math.max(max, sum);    console.log(`max=${max}`, `sum=${sum}`);  }};getMax(givenArray);


欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/zaji/5643236.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存