php求正负数数组中连续元素最大值示例_php教程-查字典教程网
php求正负数数组中连续元素最大值示例
php求正负数数组中连续元素最大值示例
发布时间:2016-12-29 来源:查字典编辑
摘要:php实现正负数数组最大子序列,要求给出数组,该数组由正负数字组成,找出该数组中连续元素组成的子数组的最大值。这其实得算是个背包变种吧。复制...

php实现正负数数组最大子序列,要求给出数组,该数组由正负数字组成,找出该数组中连续元素组成的子数组的最大值。

这其实得算是个背包变种吧。

复制代码 代码如下:

<?php

$list = array(1,-3,-5,-7,8,9,-11,5);

$cur = 0;

$term = 0;

$res = 0;

$begin = 0;

foreach($list as $k => $v){

$cur += $v;

if($cur < 0){

$cur = 0;

$begin = $k + 1;

}

if($cur > $res){

$res = $cur;

$term = $k;

}

}

$max_seq = array_slice($list, $begin, ($term - $begin) + 1);

echo $res . ',';

print_r($max_seq);

//17,Array ( [0] => 8 [1] => 9 )

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新php教程学习
    热门php教程学习
    编程开发子分类