LeetCode 53 最大子数字和(动态规划)

这是一道典型的使用动态规划解决的问题,解决难题是确定状态转移方程

题目要求是找出最大和的连续子数组,我们可以将其分解为很多个小问题,即dp

将dp定义为以每个元素结尾的和,例如【1,2,3,4,5,6】,以1结尾就一个和为1,以2结尾就两个结果1或者3,以3结尾有5个1,2,3,4,5,此处省略100行

然后我们要做的就是把他们结果中的最大值找出来,这里我确定的dp函数如下,每次找出加num[i]后的结果和num[i]的最大值存入dp中,然后不断遍历所有可能结果,将最大的取出来

cpp 复制代码
dp[i] = max(dp[i - 1] + nums[i], nums[i]);

整体代码如下:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int length = nums.size();
        vector<int> dp(length);
        dp[0] = nums[0];
        int ans = nums[0];
        for(int i = 1; i < length; i++){
            dp[i] = max(dp[i - 1] + nums[i], nums[i]);
            ans = max(ans, dp[i]);
        }
        return ans;
    }
};
相关推荐
Craaaayon2 小时前
【数据结构】二叉树-图解深度优先搜索(递归法、迭代法)
java·数据结构·后端·算法·leetcode·深度优先
高山有多高2 小时前
C语言实战项目:贪吃蛇(2)
c语言·开发语言·数据结构·c++·算法·游戏·游戏设计
徐归阳3 小时前
第三十七天:2025 图形绘制
算法
weixin_429630263 小时前
机器学习-第三章 线性模型
人工智能·算法·机器学习
补三补四5 小时前
图卷积网络 (GCN)
网络·人工智能·深度学习·神经网络·算法·机器学习
未知陨落5 小时前
LeetCode:82.杨辉三角
算法·leetcode
CoovallyAIHub5 小时前
全球首个精细梯田地块数据集GTPBD发布:为梯田遥感研究填补空白(附数据地址)
深度学习·算法·计算机视觉
CoovallyAIHub5 小时前
【一周AI风暴】周鸿祎放话“不用AI就裁员”,前谷歌CEO鼓吹对华996血拼!
深度学习·算法·计算机视觉
Miraitowa_cheems6 小时前
LeetCode算法日记 - Day 55: 子集、找出所有子集的异或总和再求和
数据结构·算法·leetcode·决策树·深度优先·剪枝