面试150 环形子数组的最大和

思路

通过分情况处理,先求出非环形情况下的最大子数组和(max_sum),然后用类似方式求出最小子数组和(min_sum)。由于环形最大子数组可能由总数组和减去中间最小子数组得到,因此再计算总和 total - min_sum 与 max_sum 进行比较,取两者的较大值作为最终答案。注意到如果数组全为负数,此时 total - min_sum 等于 0,会误导结果,因此单独判断 max_num < 0 的情况,直接返回最大值,避免错误。该方法充分利用了Kadane算法的优雅特性,时间复杂度为 O(n)。

python 复制代码
class Solution:
    def maxSubarraySumCircular(self, nums: List[int]) -> int:
        def max_sum(nums):
            cur=max_num=nums[0]
            for num in nums[1:]:
                cur=max(num,num+cur)
                max_num=max(max_num,cur)
            return max_num
        
        def min_sum(nums):
            cur=min_num=nums[0]
            for num in nums[1:]:
                cur=min(num,num+cur)
                min_num=min(min_num,cur)
            return min_num
        
        total=sum(nums)
        max_num=max_sum(nums)
        min_num=min_sum(nums)
        if max_num<0:
            return max_num #如果没有这样的话,最后会返回0,不走下面那步
        return max(max_num,total-min_num)
相关推荐
我是渣哥12 小时前
Java String vs StringBuilder vs StringBuffer:一个性能优化的探险故事
java·开发语言·jvm·后端·算法·职场和发展·性能优化
胡萝卜3.016 小时前
【LeetCode&数据结构】设计循环队列
数据结构·算法·leetcode·队列·循环队列
睡不醒的kun18 小时前
leetcode算法刷题的第二十六天
数据结构·c++·算法·leetcode·职场和发展·贪心算法
DarkLONGLOVE19 小时前
JS魔法中介:Proxy和Reflect为何形影不离?
前端·javascript·面试
jingling55519 小时前
【高级】系统架构师 | 信息系统战略规划、EAI 与新技术
程序人生·职场和发展·系统架构·学习方法·程序员创富
yinke小琪20 小时前
分库分表后,主键 ID 如何优雅生成?
java·后端·面试
Q741_1471 天前
C++ 面试高频考点 力扣 153. 寻找旋转排序数组中的最小值 二分查找 题解 每日一题
c++·算法·leetcode·面试·二分查找
小高0071 天前
🚄 前端人必收:5 分钟掌握 ES2025 超实用语法
前端·javascript·面试
麦格芬2301 天前
LeetCode 994 腐烂的橘子
算法·leetcode·职场和发展
Java中文社群1 天前
面试官:如何提升项目并发性能?
java·后端·面试