php数组内存溢出,PHP实现最大子数组算法,内存溢出,如何优化?

这是代码:

<?php

function findMaxCrossingSubarray(&$A, $low, $mid, $high){

$leftSum = -PHP_INT_MAX;

$sum = 0;

for($i = $mid; $i >= $low; $i--) {

$sum = $sum + $A[$i];

if ($sum > $leftSum) {

$leftSum = $sum;

$maxLeft = $i;

}

}

$rightSum = -PHP_INT_MAX;

$sum = 0;

for($j = $mid + 1; $j <= $high; $j++) {

$sum = $sum + $A[$j];

if ($sum > $rightSum) {

$rightSum = $sum;

$maxRight = $j;

}

}

return [

$maxLeft,

$maxRight,

$leftSum + $rightSum,

];

}

function findMaximumSubarray(&$A, $low, $high) {

if ($low === $high) {

return [

$low,

$high,

$A[$low],

];

} else {

$mid = floor(($low + $high) / 2);

list($leftLow, $leftHigh, $leftSum) = findMaximumSubarray($A, $low, $mid);

list($rightLow, $rightHigh, $rightSum) = findMaximumSubarray($A, $mid + 1, $high);

list($crossLow, $crossHigh, $crossSum) = findMaxCrossingSubarray($A, $low, $mid, $high);

if ($leftSum >= $rightSum && $leftSum >= $crossSum) {

return [

$leftLow,

$leftHigh,

$leftSum,

];

} else if ($rightSum >= $leftSum && $rightSum >= $crossSum) {

return [

$rightLow,

$rightHigh,

$rightSum,

];

} else {

return [

$crossLow,

$crossHigh,

$crossSum,

];

}

}

}

$A = [13,-3,-25,20,-3,-16,-23,18,20,-7,12,-5,-22,15,-4,7];

print_r(findMaximumSubarray($A, 0, 15));

执行结果:

Fatal error: Allowed memory size of 67108864 bytes exhausted (tried to allocate 262144 bytes) in /in/A3dLe on line 38

Process exited with code 255.

在线运行demo:https://3v4l.org/A3dLe

请问:是哪里导致的内存溢出。如何改进?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值