php求正负数数组中连续元素最大值示例
发布:smiling 来源: PHP粉丝网 添加日期:2020-11-09 11:32:55 浏览: 评论:0
问题是给出数组,该数组由正负数字组成,找出该数组中连续元素组成的子数组的最大值。下面是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 )
Tags: php正负数数组
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)