leetcode-918. 环形子数组的最大和
题目
解法
求两个值,一个是子数组最小值,一个是子数组最大值
环形数组如果没有跨最后一个那就是子数组最大值
如果跨了最后一个那就是 总数- 子数组最小值
为什么是 total-min ?
如果成环状,那么数组将被分成两段:头和尾
总数是不变的,如果其他部分加起来最大,那么中间的子数组必然加起来最小
class Solution { /** * @param Integer[] $nums * @return Integer */ function maxSubarraySumCircular($nums) { $len = count($nums); if ($len == 1) { return $nums[0]; } $total = $min = $max = $currentMin = $currentMax = $nums[0]; for ($i = 1; $i < $len; $i++) { $total += $nums[$i]; $currentMax = max($currentMax + $nums[$i], $nums[$i]); $max = max($currentMax, $max); if ($i < $len - 1) { $currentMin = min($currentMin + $nums[$i], $nums[$i]); $min = min($currentMin, $min); } } return max($max, $total - $min); } }
参考
本文来自博客园,作者:吴丹阳-V,转载请注明原文链接:https://www.cnblogs.com/wudanyang/p/15778822.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)