本文实例讲述了PHP实现求连续子数组最大和问题2种解决方法。分享给大家供大家参考,具体如下:
问题描述
求子数组的最大和
题目描述:
输入一个整形数组,数组里有正数也有负数。
数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
求所有子数组的和的最大值。要求时间复杂度为
关于连续子数组最大和这个问题,有两种解法,一种是动态规划
解法如下:
rush:
PHP;">
function getMaxSubSum($arr){
$curSum = $arr[0];
$maxSum = $arr[0];
for($i = 1; $i < count($arr); $i++){
if($curSum > 0) $curSum += $arr[$i];
else $curSum = $arr[$i];
if($curSum > $maxSum) $maxSum = $curSum;
}
return $maxSum;
}
还有一种是扫描法
rush:
PHP;">
function getMaxSubSum($arr){
$curSum = 0;
$maxSum = 0;
for($i = 0; $i < count($arr); $i++ ){
$curSum += $arr[$i];
if($curSum <= 0) $curSum = 0;
if($curSum > $maxSum) $maxSum = $curSum;
}
if($maxSum == 0){
$maxSum = $arr[0];
for($i = 1; $i < count($arr); $i++){
if($maxSum < $arr[$i] ) $maxSum = $arr[$i];
}
}
return $maxSum;
}
更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》及《PHP常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
原文地址:https://www.jb51.cc/php/16451.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。