码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • leetCode 53.最大子数组和 动态规划 + 优化空间复杂度


    关于此题我的往期文章:

    leetCode 53.最大子数和 图解 + 贪心算法/动态规划+优化_呵呵哒( ̄▽ ̄)"的博客-CSDN博客icon-default.png?t=N7T8https://heheda.blog.csdn.net/article/details/13349726853. 最大子数组和 - 力扣(LeetCode)

    >>思路和分析

    子数组:其实就是连续的子序列

    • 思考:求这个数组的最大子序和是多少?什么是最大子序和?

    其实指的就是它的子数组的最大和,子数组其实就是连续的子序列。也就是在数组里边,找到一个连续的子序列,它的和一定是所有的连续子序列里边最大的,最后把这个和输出来。

    >>动规五部曲

    1.确定dp数组(dp table)以及下标的含义

    • dp[i]:包括下标i(以nums[i]为结尾)的最大连续子序列的和 为 dp[i]

    2.确定递推公式

    重要关键词:“延续”和 “不延续”

    • 情况① “延续” 着前面的子序列,继续前面的子序列的和我继续累加着,
      • 即dp[i] = dp[i-1] + nums[i];
    • 情况② “不延续” 着前面的子序列,前面的子序列的和我不要了,从我这里从头开始计算,
      • dp[i] = nums[i];

    故dp[i]只有两个方向可以推出来

    • dp[i-1] + nums[i],即:nums[i]加入当前连续子序列和
    • nums[i],即:从头开始计算当前连续子序列和

    一共就这两种情况,取它们的最大值,所以dp[i] = max(dp[i-1]+nums[i],nums[i]);

    3.dp数组初始化

    从递推公式可知,dp[i] 依赖于 dp[i-1] 的状态,dp[0]是递推公式的基础

    • dp[0] = nums[0]
    • 非0下标的值初始化成什么都可以,因为都会被覆盖掉

    因此可统一初始化dp数组为0,dp[0]单独赋值,即

    • vectordp(nums.size(),0);
    • dp[0]=nums[0];

    4.确定遍历顺序

    • 递推公式中dp[i] 依赖于dp[i-1] 的状态,需要从前向后遍历

    5.举例推导dp数组

    1. class Solution {
    2. public:
    3. // 动态规划
    4. int maxSubArray(vector<int>& nums) {
    5. if(nums.size() == 0) return 0;
    6. vector<int>dp(nums.size(),0);
    7. dp[0] = nums[0];
    8. int result = dp[0];// 注意点!
    9. for(int i=1;isize();i++) {
    10. dp[i] = max(dp[i-1]+nums[i],nums[i]);// 状态转移公式
    11. if(dp[i] > result) result = dp[i]; // result 保存dp[i]的最大值
    12. }
    13. return result;
    14. }
    15. };
    • 时间复杂度:O(n)
    • 空间复杂度:O(n)

    >>优化空间复杂度

    1. class Solution {
    2. public:
    3. // 动态规划 优化空间复杂度
    4. int maxSubArray(vector<int>& nums) {
    5. if(nums.size() == 0) return 0;
    6. vector<int>dp(2,0);
    7. dp[0] = nums[0];
    8. int result = dp[0];// 注意点!
    9. for(int i=1;isize();i++) {
    10. dp[i % 2] = max(dp[(i-1) % 2]+nums[i],nums[i]);// 状态转移公式
    11. if(dp[i % 2] > result) result = dp[i % 2];// result 保存dp[i]的最大值
    12. }
    13. return result;
    14. }
    15. };
    • 时间复杂度:O(n)
    • 空间复杂度:O(1)

    来自代码随想录课堂截图:

    参考和推荐文章、视频:

    代码随想录 (programmercarl.com)icon-default.png?t=N7T8https://programmercarl.com/0053.%E6%9C%80%E5%A4%A7%E5%AD%90%E5%BA%8F%E5%92%8C%EF%BC%88%E5%8A%A8%E6%80%81%E8%A7%84%E5%88%92%EF%BC%89.html#%E6%80%9D%E8%B7%AF

    看起来复杂,其实是简单动态规划 | LeetCode:53.最大子序和_哔哩哔哩_bilibiliicon-default.png?t=N7T8https://www.bilibili.com/video/BV19V4y1F7b5/?spm_id_from=333.788&vd_source=a934d7fc6f47698a29dac90a922ba5a3推荐我的往期文章:leetCode 53.最大子数和 图解 + 贪心算法/动态规划+优化_呵呵哒( ̄▽ ̄)"的博客-CSDN博客icon-default.png?t=N7T8https://heheda.blog.csdn.net/article/details/133497268

     

  • 相关阅读:
    软件测试/测试开发丨​利用ChatGPT编写测试用例
    JavaScript基础知识: 原型和原型链
    消息队列——rabbitmq的不同工作模式
    腾讯云架构师整理总结的MySQL性能优化和高可用架构实践文档
    Linux------环境变量
    从0到1,企业如何快速构建自己的销售体系
    云原生技术盛会KubeCon即将召开!亚马逊云科技作为钻石赞助商参会
    Spark - Task 与 Partition 一一对应与参数详解
    电脑屏幕实时监控软件有哪些(监控电脑操作的软件叫什么?)
    Dotnet 序列化枚举为字符串
  • 原文地址:https://blog.csdn.net/weixin_41987016/article/details/133743981
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号