首页 > 其他 > 详细

最大子阵列和

时间:2017-07-24 18:34:43      阅读:262      评论:0      收藏:0      [点我收藏+]

最大和子数组问题在于找到数组或整数列表中的连续子序列的最大和:

maxSequence([-2, 1, -3, 4, -1, 2, 1, -5, 4])
// should be 6: [4, -1, 2, 1]

简单的情况是当列表仅由正数组成时,最大和是整个数组的总和。如果列表仅由负数组成,则返回0。

空列表被认为具有零最大和。请注意,空列表或数组也是有效的子列表/子阵列。

var maxSequence = function(arr){
var max=0;
if(arr.length==0){
return 0;
}
for(var i=0;i<arr.length;i++){
var sum=arr[i];
for(var j=i+1;j<arr.length;j++){
sum+=arr[j];
if(sum>max){
max=sum;

}
}
}
return max;
}

思路:通过循环可以获取arr中所有的值,先设置一个最大值,给数组中的每一位从前向后增加的计算,每一次计算都对比这个值与最大值的大小,即可得到最大子阵列和


最大子阵列和

原文:http://www.cnblogs.com/chengnanbei/p/7230054.html

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