leetcode hot100 53.最大子数组和 动态规划 medium

暴力解法超出时间

python 复制代码
class Solution:
    def maxSubArray(self, nums: List[int]) -> int:
        if not nums:
            return 0

        left = 0
        maxsum = -float('inf') 

        for right in range(len(nums)):
            winsum = 0
            for i in range(right, len(nums)):
                winsum += nums[i]
                maxsum = max(winsum, maxsum)
        return maxsum

动态规划的状态定义

设 dp[i] 表示以 nums[i] 结尾的子数组的最大和:

  1. 如果dp[i-1]是负数,那么无论nums[i]是正数还是负数,以nums[i]结尾的子数组的最大和dp[i] 为nums[i]。 (不要累加前面的负数结果)
  2. 如果dp[i-1]是正数,那么无论nums[i]是正数还是负数,以nums[i]结尾的子数组的最大和号dp[i] 为dp[i-1]+nums[i]。 (累加前面的正数结果)

即每轮迭代 dp[i] 的更新为:dp[i] = max(nums[i], dp[i-1] + nums[i])

再与之前的迭代结果比较: maxsum = max(dp[i] ,maxsum)

python 复制代码
class Solution:
    def maxSubArray(self, nums: List[int]) -> int:
        if not nums:
            return 0

        dp = [0] * len(nums)
        dp[0] = nums[0]
        maxsum = dp[0]

        for i in range(1,len(nums)):
            dp[i] = max(nums[i], dp[i-1] + nums[i])

            maxsum = max(maxsum, dp[i])

        return maxsum
        

时间复杂度:O(n),其中 n 是数组的长度,因为我们只遍历一遍数组。

空间复杂度:O(n),需要存储 dp 数组

相关推荐
TracyCoder12317 小时前
LeetCode Hot100(22/100)——141. 环形链表
算法·leetcode·链表
罗湖老棍子18 小时前
【区间DP】括号序列:如何求解最长合法子序列?(POJ 2955)
算法·动态规划·区间dp·区间动态规划·端点匹配型
沉睡的无敌雄狮18 小时前
陌讯视觉如何凭垂直场景闭环能力中标公安智能防控与万象城客流系统?
逻辑回归·动态规划
重生之后端学习18 小时前
146. LRU 缓存
java·数据结构·算法·leetcode·职场和发展
程曦曦18 小时前
原地删除有序数组重复项:双指针法的艺术与实现
数据结构·算法·leetcode
iAkuya18 小时前
(leetcode)力扣100 60单词搜索(回溯)
算法·leetcode·职场和发展
圣保罗的大教堂18 小时前
leetcode 3637. 三段式数组 I 简单
leetcode
2401_8414956419 小时前
【LeetCode刷题】对称二叉树
数据结构·python·算法·leetcode·二叉树··递归
觅特科技-互站20 小时前
非替代,是升维:陌讯‘动态语义聚类’重构聚众识别——三省应急指挥中心实录
逻辑回归·动态规划
We་ct20 小时前
LeetCode 49. 字母异位词分组:经典哈希解法解析+易错点规避
前端·算法·leetcode·typescript·哈希算法