最大子数组和问题:从暴力到Kadane算法的优雅蜕变

最大子数组和问题:从暴力到Kadane算法的优雅蜕变

给定一个整数数组,找出和最大的连续子数组(至少包含一个元素),并返回这个最大和。这个问题在面试中出现的频率相当高,今天我们就来彻底搞懂它。

示例:

  • 输入:arr\[\] = 2, 3, -8, 7, -1, 2, 3 → 输出:11(子数组7, -1, 2, 3的和)
  • 输入:arr\[\] = -2, -4 → 输出:-2(子数组-2的和)
  • 输入:arr\[\] = 5, 4, 1, 7, 8 → 输出:25(整个数组的和)

目录


学习最大子数组和问题时,从暴力解法到Kadane算法的优化过程,光靠文字推导很容易卡壳。最近发现一个叫图码的宝藏网站,把60多种算法做成交互式动画可视化,比如Kadane算法的状态转移过程,每一步都动态展示,非常直观。更绝的是,它支持输入自定义数据跑动画,甚至上传C/C++/Java/Python代码自动解析,对准备408考研数据结构期末考试特别友好。建议直接去体验一下,边看动画边理解,效率高很多。

图码-数据结构与算法交互式可视化平台

访问网站:https://totuma.cn

暴力解法:遍历所有子数组

最直观的方法就是枚举所有可能的子数组,计算每个子数组的和,记录最大值。

思路: 外层循环确定子数组的起点,内层循环确定终点,累加并更新最大值。

python 复制代码
def maxSubarraySum(arr):
    res = arr[0]
    for i in range(len(arr)):
        currSum = 0
        for j in range(i, len(arr)):
            currSum += arr[j]
            res = max(res, currSum)
    return res

复杂度分析:

  • 时间复杂度:O(n²) ------ 两层嵌套循环
  • 空间复杂度:O(1) ------ 只用了常数空间

当数组规模较大时,O(n²)的算法显然不够高效。我们需要更优的解法。


Kadane算法:线性时间解决

Kadane算法的核心思想是动态规划:对于每个位置,我们计算以该位置结尾的最大子数组和,然后取全局最大值。

核心思路:

  • 维护两个变量:res(全局最大和)和maxEnding(以当前位置结尾的最大和)
  • 遍历数组时,对于每个元素,有两种选择:
    1. 将当前元素加入之前的子数组(扩展)
    2. 从当前元素开始新的子数组
  • 选择两者中较大的作为新的maxEnding
  • 更新全局最大值res

算法步骤图解:

以数组2, 3, -8, 7, -1, 2, 3为例:

  • 初始:res = 2, maxEnding = 2
  • i=1 (3): maxEnding = max(3, 2+3) = 5, res = max(2,5) = 5
  • i=2 (-8): maxEnding = max(-8, 5-8) = -3, res = max(5,-3) = 5
  • i=3 (7): maxEnding = max(7, -3+7) = 7, res = max(5,7) = 7
  • i=4 (-1): maxEnding = max(-1, 7-1) = 6, res = max(7,6) = 7
  • i=5 (2): maxEnding = max(2, 6+2) = 8, res = max(7,8) = 8
  • i=6 (3): maxEnding = max(3, 8+3) = 11, res = max(8,11) = 11

最终结果:11

python 复制代码
def maxSubarraySum(arr):
    res = arr[0]
    maxEnding = arr[0]
    
    for i in range(1, len(arr)):
        maxEnding = max(maxEnding + arr[i], arr[i])
        res = max(res, maxEnding)
    
    return res

复杂度分析:

  • 时间复杂度:O(n) ------ 只需遍历一次数组
  • 空间复杂度:O(1) ------ 只用了常数空间

总结

算法 时间复杂度 空间复杂度 适用场景
暴力法 O(n²) O(1) 小规模数据或教学演示
Kadane算法 O(n) O(1) 大规模数据,实际应用

Kadane算法是解决最大子数组和问题的标准解法,其思想还可以推广到其他类似问题,如最大乘积子数组等。掌握这个算法,面试中遇到类似问题就能游刃有余了!


相关文章推荐:

  • 打印最大和子数组
  • 最大乘积子数组
  • 重复拼接数组的最大子数组和
相关推荐
kkeeper~1 天前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
2401_868534781 天前
论企业网络设计
数据结构
wabs6661 天前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964131 天前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚1 天前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本1 天前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov1 天前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫1 天前
特征工程处理
人工智能·算法·机器学习
z落落1 天前
C#参数区别
java·算法·c#
c238561 天前
vector(下)
数据结构·算法