码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode刷题笔记【31】:动态规划专题-3(整数拆分、不同的二叉搜索树)


    文章目录

    • 前置知识
    • 343. 整数拆分
      • 题目描述
      • 解题思路
      • 代码
      • 进一步优化
    • 96.不同的二叉搜索树
      • 题目描述
      • 解题思路
      • 代码
      • 优化改进
    • 总结

    前置知识

    参考前文

    参考文章:
    LeetCode刷题笔记【29】:动态规划专题-1(斐波那契数、爬楼梯、使用最小花费爬楼梯)
    LeetCode刷题笔记【30】:动态规划专题-2(不同路径、不同路径 II)

    343. 整数拆分

    题目描述

    截图

    LeetCode链接:https://leetcode.cn/problems/integer-break/description/

    解题思路

    思路: 动态规划
    建立dp数组, 表示下标i的最大乘积
    对每个新的i, 将i分成(i=x+y), dp[i] = max(dp[x], x) * max(dp[y], y);

    代码

    class Solution {
    public:
        int integerBreak(int n) {
            vector<int> dp(n+1, INT_MIN);
            dp[0] = 0;
            dp[1] = 0;
            dp[2] = 1;
            if(n<=2)
                return dp[n];
            for(int i=3; i<=n; ++i){
                for(int x=1; x<=i/2; ++x){
                    int y = i-x;
                    dp[i] = max(dp[i], max(dp[x], x) * max(dp[y], y));
                }
            }
            return dp[n];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    进一步优化

    可以将递推构建dp数组的过程进一步简化为以下形式
    效率会更高, 但是理解起来困难一些, 也不容易想到

    for (int i = 3; i <= n ; i++) {
        for (int j = 1; j <= i / 2; j++) {
            dp[i] = max(dp[i], max((i - j) * j, dp[i - j] * j));
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    96.不同的二叉搜索树

    题目描述

    截图

    LeetCode链接:https://leetcode.cn/problems/unique-binary-search-trees/description/

    解题思路

    动态规划
    dp数组中dp[i]表示有i个节点的时候有dp[i]种搜素树
    dp[0]=0, dp[1]=1, dp[2]=2
    求dp[i]的时候, 用j遍历1到i, dp[i] += dp[j-1] * dp[i-j];
    在这里插入图片描述

    代码

    class Solution {
    public:
        int numTrees(int n) {
            vector<int> dp(max(n+1,5),0);
            dp[0] =1;
            dp[1] = 1;
            dp[2] = 2;
            if(n<=2)
                return dp[n];
            for(int i=3; i<=n; ++i){
                for(int j=1; j<=i; ++j){
                    dp[i] += dp[j-1] * dp[i-j];
                }
            }
            return dp[n];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    优化改进

    不用初始化到2, 到1就行了

    class Solution {
    public:
        int numTrees(int n) {
            vector<int> dp(n+1,0);
            dp[0] =1;
            dp[1] = 1;
            for(int i=2; i<=n; ++i){
                for(int j=1; j<=i; ++j){
                    dp[i] += dp[j-1] * dp[i-j];
                }
            }
            return dp[n];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    总结

    很多动态规划题目, 因为涉及到递推, 前后数值的查询, 所以直接脑中空想比较困难;
    想不清楚的时候最好动笔写写画画, 思路会清晰很多.

    本文参考:
    整数拆分
    不同的二叉搜索树

  • 相关阅读:
    详解Spark运行模式(local+standalone+yarn)
    分类预测 | MATLAB实现SSA-FS-SVM麻雀算法同步优化特征选择结合支持向量机分类预测
    React ReactRouter6、组件的调整、hooks(笔记)
    如何回复SCI审稿人评审意见(response letter)
    Mysql按照中文首字母排序
    .NET周刊【10月第1期 2023-10-01】
    d栈上的类
    linux目录权限、文件权限及修改权限操作
    Rabbitmq安装-docker版
    14-兼容性处理
  • 原文地址:https://blog.csdn.net/Eibosinu/article/details/132756990
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号