php实现最大子序和算法
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
示例:
输入: [-2,1,-3,4,-1,2,1,-5,4],
输出: 6(最大子序列:4 -1 2 1 )
第一种:
$arr = [-2,1,-3,4,-1,2,1,-5,4]; function maxSubArray($nums) { for($i=1;$i<count($nums);$i++) $nums[$i] = max($nums[$i],$nums[$i]+$nums[$i-1]); return max($nums); } echo maxSubArray($arr);
第二种:
$arr = [-2,1,-3,4,-1,2,1,-5,4]; $len = count($arr); $b =[]; $b[0] = $arr[0]; $max = $arr[0] >0 ?$arr[0]:0; $start_x = 0; for($i=1;$i<$len;$i++) { if(($b[$i-1] + $arr[$i]) > $arr[$i]){ $b[$i] = $b[$i-1] + $arr[$i]; }else{ $b[$i] = $arr[$i]; $start_x = $i; ; } if($max < $b[$i]) { $max = $b[$i]; $end_x = $i; } } print '最大子和: '.$max."\n"; print '开始位置: '.$start_x."\t"; print '结束位置: '.$end_x."\n"; print '最大子序列:'; for($i=$start_x;$i<=$end_x;$i++){ print $arr[$i].' '; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!