【算法题】53. 最大子数组和-力扣(LeetCode)

【算法题】53. 最大子数组和-力扣(LeetCode)

1.题目

下方是力扣官方题目的地址

53. 最大子数组和

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组

是数组中的一个连续部分。

示例 1:

复制代码
输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

示例 2:

复制代码
输入:nums = [1]
输出:1

示例 3:

复制代码
输入:nums = [5,4,-1,7,8]
输出:23

提示:

  • 1 <= nums.length <= 105
  • -104 <= nums[i] <= 104

2.题解

思路

本题很显然可以用动态规划的思路

我们可以将该问题转换为子问题,找到这些子问题的状态转移方程

这个问题就可以轻松地解决了

我们用 dpi 代表以第 i个数结尾的连续子数组的最大和

dpi的得出有两种情况:

1.单独自成一个序列,从numi开始

2.加入dpi-1的那一段序列

由这两个情况可以很容易得出状态转移方程:

dp[i]=max(dp[i-1]+nums[i],nums[i])

得出了状态转移方程,这个问题也就迎刃而解了

Python代码

python 复制代码
class Solution(object):
    def maxSubArray(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        dp=[0]*len(nums)        # 初始化dp数组
        dp[0]=nums[0]
        for i in range(1,len(nums)):
            dp[i]=max(dp[i-1]+nums[i],nums[i])      # 利用状态转移方程
        return max(dp)

3.结语

本人资历尚浅,发博客主要是记录与学习,欢迎大佬们批评指教!大家也可以在评论区多多交流,相互学习,共同成长。

相关推荐
JAVA面经实录9176 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
开源Z7 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎8 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
syagain_zsx8 小时前
STL 之 vector 讲练结合
c++·算法
MartinYeung510 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
Tian_Hang10 小时前
C++原型模式(Protype)
开发语言·c++·算法
bIo7lyA8v10 小时前
算法复杂度的渐进分析与实际运行时间的差异的技术8
算法
yuan1999711 小时前
欧拉梁静力与屈曲计算的 MATLAB 实现(有限差分法 + 解析解)
开发语言·算法·matlab
汉克老师12 小时前
GESP7级C++考试语法知识(二、指数函数(3、综合练习)
c++·算法·数学建模·指数函数·gesp7级·复利