面试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)
相关推荐
liangdabiao4 小时前
LangGraph大法好:工作流编排框架,特别适合构建复杂的多步骤、有状态或协作式 AI 应用
后端·面试·github
qq_417719985 小时前
免费的大模型面试辅导系列课程
人工智能·深度学习·chatgpt·面试·职场和发展·求职招聘
顾林海5 小时前
Dart 异步编程之 Future 详解
flutter·面试·dart
GISer_Jing5 小时前
同花顺前端潜在面试题目与答案
前端·面试·职场和发展
三小河5 小时前
eslint 配置 import 的引入规则
前端·javascript·面试
月阳羊6 小时前
【硬件-笔试面试题】硬件/电子工程师,笔试面试题-3,(运放/三极管)
面试·职场和发展
爱coding的橙子6 小时前
每日算法刷题Day52:7.24:leetcode 栈5道题,用时1h35min
算法·leetcode·职场和发展
居然JuRan7 小时前
RAG 技术深度面试题:架构、优化与实践应用
机器学习·面试
前端拿破轮7 小时前
二叉树的最小深度——和最大深度一样的逻辑?
算法·设计模式·面试
Java技术小馆8 小时前
Arthas让线上问题定位变得简单
后端·面试·架构