php求正负数数组中连续元素最大值示例

问题是给出数组,该数组由正负数字组成,找出该数组中连续元素组成的子数组的最大值。下面是PHP实现的示例,需要的朋友可以参考下。

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

这其实得算是个背包变种吧,代码如下:

  1. <?php
  2. $list = array(1,-3,-5,-7,8,9,-11,5);
  3. $cur = 0;
  4. $term = 0;
  5. $res = 0;
  6. $begin = 0;
  7. foreach($list as $k => $v){
  8. $cur += $v;
  9. if($cur < 0){
  10. $cur = 0;
  11. $begin = $k + 1;
  12. }
  13. if($cur > $res){
  14. $res = $cur;
  15. $term = $k;
  16. }
  17. }
  18. $max_seq = array_slice($list, $begin, ($term - $begin) + 1);
  19. echo $res . ',';
  20. print_r($max_seq);
  21. //17,Array ( [0] => 8 [1] => 9 )