面试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)
相关推荐
独行soc8 小时前
2025年渗透测试面试题总结-18(题目+回答)
android·python·科技·面试·职场和发展·渗透测试
艾伦~耶格尔9 小时前
【数据结构进阶】
java·开发语言·数据结构·学习·面试
愿天堂没有C++10 小时前
剑指offer第2版——面试题4:二维数组中的查找
c++·面试
gzzeason13 小时前
LeetCode Hot100:递归穿透值传递问题
算法·leetcode·职场和发展
夏日不想说话16 小时前
API请求乱序?深入解析 JS 竞态问题
前端·javascript·面试
掘金安东尼16 小时前
我们让 JSON.stringify 的速度提升了两倍以上
前端·javascript·面试
诗书画唱17 小时前
学习笔记与效率提升指南:编程、记忆与面试备考
笔记·学习·面试
sufu106517 小时前
说说内存泄漏的常见场景和排查方案?
java·开发语言·面试
small_wh1te_coder19 小时前
GCC深度剖析:从编译原理到嵌入式底层实战
汇编·c++·面试·嵌入式·状态模式·c
闪电麦坤9520 小时前
数据结构:用链表实现队列(Implementing Queue Using List)
数据结构·链表·队列