PHP求最大子序列和的算法实现


Posted in PHP onJune 24, 2011
<?php 
//作者:遥远的期待 
//QQ:15624575 
//算法分析:1、必须是整数序列、2、如果整个序列不全是负数,最大子序列的第一项必须是正数,否则最大子序列后面的数加起来再加上第一项的负数,其和肯定不是最大的;3、如果整个序列都是负数,那么最大子序列的和是0; 
//全负数序列很简单,不举例 
$arr=array(4,-3,5,-2,-1,2,6,-2); 
function getmaxsum($arr){ 
$thissum=0; 
$maxsum=0; 
$start=0;//记录子序列的起始下标 
$end=0;//记录子序列的结束下标 
for($i=0;$i<count($arr);$i++){ 
$thissum+=$arr[$i];//取得当前子序列的和 
if($thissum>$maxsum){//如果当前子序列的和大于当前最大子序列的和 
$maxsum=$thissum;//改变当前最大子序列的和 
$end=$i; 
}else if($thissum<0){//如果当前子序列的和小于0,则把下一个元素值假定为最大子序列的第一项,这里可以保证最大自序列的第一项一定是正数 
$thissum=0;//前提这个序列不全是负数 
$start=$i+1; 
} 
} 
$parr=array($start,$end,$maxsum); 
return $parr; 
} 
list($start,$end,$maxsum)=getmaxsum($arr); 
echo '最大子序列是:'; 
for($i=$start;$i<=$end;$i++){ 
echo $arr[$i].' '; 
} 
echo '<br>'; 
echo '最大子序列的和是'.$maxsum; 
?>
PHP 相关文章推荐
模拟flock实现文件锁定
Feb 14 PHP
php下检测字符串是否是utf8编码的代码
Jun 28 PHP
用PHP读取flv文件的播放时间长度
Sep 03 PHP
php5.3中连接sqlserver2000的两种方法(com与ODBC)
Dec 29 PHP
php sybase_fetch_array使用方法
Apr 15 PHP
又一个PHP实现的冒泡排序算法分享
Aug 21 PHP
Smarty中调用FCKeditor的方法
Oct 27 PHP
thinkphp如何获取客户端IP
Nov 03 PHP
php基于curl实现的股票信息查询类实例
Nov 11 PHP
PHP registerXPathNamespace()函数讲解
Feb 03 PHP
TP5框架页面跳转样式操作示例
Apr 05 PHP
PHP7 弃用功能
Mar 09 PHP
php中转义mysql语句的实现代码
Jun 24 #PHP
把1316这个数表示成两个数的和,其中一个为13的倍数,另一个是11的倍数,求这两个数。
Jun 24 #PHP
php中对2个数组相加的函数
Jun 24 #PHP
php判断输入不超过mysql的varchar字段的长度范围
Jun 24 #PHP
PHP array操作10个小技巧分享
Jun 23 #PHP
php 缩略图实现函数代码
Jun 23 #PHP
php中随机显示图片的函数代码
Jun 23 #PHP
You might like
PHP 字符串编码截取函数(兼容utf-8和gb2312)
2009/05/02 PHP
php 解决substr()截取中文字符乱码问题
2016/07/18 PHP
php 广告点击统计代码(php+mysql)
2018/02/21 PHP
PHP利用递归函数实现无限级分类的方法
2019/03/22 PHP
PHP扩展安装方法步骤解析
2020/11/24 PHP
Javascript之文件操作
2007/03/07 Javascript
从新浪弄下来的全屏广告代码 与使用说明
2007/03/15 Javascript
javascript十个最常用的自定义函数(中文版)
2009/09/07 Javascript
分享精心挑选的12款优秀jQuery Ajax分页插件和教程
2012/08/09 Javascript
分析Node.js connect ECONNREFUSED错误
2013/04/09 Javascript
js中单引号与双引号冲突问题解决方法
2013/10/04 Javascript
使用JS CSS去除IE链接虚线框的三种方法
2013/11/14 Javascript
完美兼容各大浏览器的jQuery仿新浪图文淡入淡出间歇滚动特效
2014/11/12 Javascript
js分页工具实例
2015/01/28 Javascript
JS实现的通用表单验证插件完整实例
2015/08/20 Javascript
Javascript动画效果(1)
2016/10/11 Javascript
jQuery居中元素scrollleft计算方法示例
2017/01/16 Javascript
使用JavaScript触发过渡效果的方法
2017/01/19 Javascript
vue-resource调用promise取数据方式详解
2017/07/21 Javascript
EasyUI框架 使用Ajax提交注册信息的实现代码
2017/09/27 Javascript
vue.js 微信支付前端代码分享
2018/02/10 Javascript
vue数据控制视图源码解析
2018/03/28 Javascript
node.js如何根据URL返回指定的图片详解
2020/10/21 Javascript
Python基于Matplotlib库简单绘制折线图的方法示例
2017/08/14 Python
Python将多个list合并为1个list的方法
2018/06/27 Python
Pandas DataFrame数据的更改、插入新增的列和行的方法
2019/06/25 Python
Python爬虫入门教程01之爬取豆瓣Top电影
2021/01/24 Python
使用canvas生成含有微信头像的邀请海报没有微信头像问题
2019/10/29 HTML / CSS
中国高端鲜花第一品牌:roseonly(一生只送一人)
2017/02/12 全球购物
中文专业毕业生自荐信
2013/10/28 职场文书
制定岗位职责的原则
2013/11/08 职场文书
干部下基层实施方案
2014/03/14 职场文书
反腐倡廉剖析材料
2014/09/30 职场文书
被告代理词范文
2015/05/25 职场文书
MySQL Shell的介绍以及安装
2021/04/24 MySQL
前端传参数进行Mybatis调用mysql存储过程执行返回值详解
2022/08/14 MySQL