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

Problem: 53. 最大子数组和

文章目录

题目描述

思路及解法

1.定义dp数组:dpi表示以numsi为结尾的子序列的最大子序列和;

2.状态初始化:dp0 = nums0,表示以nums0为结尾的子序列的最大子序列和为nums0本身;

3.状态转移:注意上述定义的dp表示的实际意义是numsi为结尾的子序列的最大子序列和 ;若当前已经得到dpi-1,则对于dpi我们要么在dpi-1的基础上再选择讲numsi加进来组成一个以numsi为结尾的最大子序列,要么直接选择numsi;所以直接在二者中选择一个较大的赋值给dpi即可

4.计算结果:在dp数组中选出最大的值返回即可;

复杂度

时间复杂度:

O ( n ) O(n) O(n);其中 n n n为原数组 n u m s nums nums的大小

空间复杂度:

O ( 1 ) O(1) O(1)

Code

cpp 复制代码
class Solution {
public:
    /**
     * Dynamic programing
     * @param nums Given arr
     * @return int
     */
    int maxSubArray(vector<int>& nums) {
        int n = nums.size();
        vector<int> dp(n + 1);
        dp[0] = nums[0];
        for (int i = 1; i < n; ++i) {
            dp[i] = max(dp[i - 1] + nums[i], nums[i]);
        }
        int max = INT_MIN;
        for (int i = 0; i < n; ++i) {
            if (dp[i] > max) {
                max = dp[i];
            } 
        }
        return max;
    }
};
相关推荐
月光刺眼17 分钟前
🎶二分 · 双指针 · 滑动窗口 · 螺旋矩阵:数组算法四题拆解
javascript·算法
海清河晏11124 分钟前
字符串匹配:BF算法与KMP算法
数据结构·算法·visual studio
学计算机的计算基31 分钟前
LeetCode刷题笔记:数组专题四连击(LC53/56/189/41)
笔记·leetcode·排序算法
wandertp32 分钟前
对信号处理及滤波器的理解---基于robomaster机器人嵌入式控制系统
arm开发·stm32·算法·信号处理
z小猫不吃鱼36 分钟前
15 InstructGPT 论文精读:SFT + RLHF 如何让模型听懂指令?
人工智能·深度学习·算法·机器学习·语言模型·自然语言处理·gpt-3
见合八方1 小时前
【滤波器】热调谐FP滤波器
人工智能·算法
古城小栈1 小时前
cargo-pprof:Rust性能调优
人工智能·算法·rust
x_xbx1 小时前
LeetCode:543. 二叉树的直径
算法·leetcode·职场和发展
汉克老师1 小时前
GESP6级C++考试语法知识(三十九、动态规划的启蒙(四、二维DP))
c++·动态规划·dp·gesp六级·二维dp
QiLinkOS1 小时前
QiLink 技术委员会选举实施细则
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源