动态规划-53.最大子数组和-力扣(LeetCode)

一、题目解析

在给定顺序的数组中找出一段具有最大和的连续子数组,且大小最小为1.

二、算法原理

1.状态表示

我们可以意一一枚举出所有的子数组,但我们想要的是最大子数组,所以fi表示:以i位置为结尾,所有子数组的最大和

2.状态转移方程

fi当长度为1时,此时的子数组和为numsi,当长度大于1时,此时的子数组和为0,i-1的子数组最大值加上numsi,我们需要取二者中的最大值。

所以fi=max(numsi,fi-1+numsi);

3.初始化

在计算fi中我们用到了fi-1当i处于0位置时,越界访问,所以我们可以直接初始化f0,或者加一个虚拟格子用于初始化。

4.填表顺序

从左到右填表,保证所需值已计算

5.返回值

由于fi中存储的是到达i位置的最大子数组和,我们需要知道从0,n-1 区间内的最大值,所以返回值为fi中的最大值

思考与实践同等重要,在思考后可以去实现一下,链接:53. 最大子数组和 - 力扣(LeetCode)

三、代码示例

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int n = nums.size();
        vector<int> dp(n+1);
        for(int i = 1;i<=n;i++)
        {
            dp[i] = max(nums[i-1],dp[i-1]+nums[i-1]);
        }
        int MAX = INT_MIN;//数组中存在负数,所以在比大小时用int的最小值比较,也可以赋值f[1]从2到n开始比较
        for(int i = 1;i<=n;i++)
        {
            if(dp[i]>MAX) MAX = dp[i];
        }

        return MAX;
    }
};

看到最后,如果对您有所帮助请点赞、收藏和关注, 点点关注不迷路,我们下期再见!

相关推荐
JieE21215 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4563 天前
C++进阶(1)——前景提要
c++