用分治法求一个数组的最大子数组

//考虑最最大子数组穿过了中间元素mid

function Find_crossing_Subarray(arr,low,mid,high){
  var left_sum=Number.NEGATIVE_INFINITY;
  var right_sum=Number.NEGATIVE_INFINITY;
  var sum_l=0,sum_r=0;
  var max_left,max_right;
  for(var i=mid;i>=low;i--){
    sum_l=sum_l+arr[i];
    if(sum_l>left_sum){
      left_sum=sum_l;
      max_left=i;
    }
  }
for(var i=mid+1;i<high;i++){
  sum_r=sum_r+arr[i];
  if(sum_r>right_sum){
    right_sum=sum_r;
    max_right=i;
  }
}
return left_sum+right_sum;
}

//求最大子数组的代码

function Find_Max_Subarray(arr,low,high){
  var left_max,right_max,crossing_max;
  if(low==high){
    return arr[low];
  }

  else {
   var  mid=Math.floor((low+high)/2);

//递归求出mid左边的最大子数组元素之和
    left_max=Find_Max_Subarray(arr, low,mid);

//递归求出mid右边的最大子数组元素之和
    righ_max=Find_Max_Subarray(arr,low+1,high);

//求出穿过mid时的情况
    crossing_max=Find_crossing_Subarray(arr,low,mid,high);

//比较找出三者最大的。
  if(left_max>right_max&&left_max>crossing_max){
    return left_max;
  }
  else if(right_max>left_max&&right_max>crossing_max){
    return right_max;
  }
  else return crossing_max;
  }
}

转载于:https://my.oschina.net/u/2604302/blog/632681

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值