Day40| 343 整数拆分 96 不同的二叉搜索树

目录

[343 整数拆分](#343 整数拆分)

[96 不同的二叉搜索树](#96 不同的二叉搜索树)


343 整数拆分

cpp 复制代码
class Solution {
public:
    int integerBreak(int n) {
        vector<int> dp(n + 1);
        dp[2] = 1;

        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));
            }
            cout << "dp[" << i << "] = " << dp[i] << endl;
        }
        return dp[n];
    }
};

96 不同的二叉搜索树

cpp 复制代码
class Solution {
public:
    int numTrees(int n) {
        //1 第 i 个数有dp[i]种不同的二叉树数量
        vector<int> dp(n + 1, 0);
        //2 初始化
        dp[0] = 1;
        dp[1] = 1;
        //3 数组遍历
        for(int i = 2; i <= n; i++){
            for(int j = 1; j <= i; j++){
                //4 递归方程
                dp[i] += dp[j - 1] * dp[i - j];
            }
        }
        return dp[n];
    }
};
相关推荐
OKkankan几秒前
排序(数据结构)
c语言·数据结构·c++·算法
m0_663234013 小时前
Rust并发编程实践:10分钟入门系统级编程
python·算法·rust
zdsji3 小时前
如何制作安装包打包软件
算法·rust·vue
糖葫芦君4 小时前
TD时间差分算法
人工智能·算法
半桔5 小时前
C++入门
c语言·开发语言·数据结构·c++·vscode·青少年编程
_nut_6 小时前
手撕跳表/数据结构
java·开发语言·数据结构
刘大猫267 小时前
十、MyBatis的缓存
大数据·数据结构·人工智能
没明白白7 小时前
插入排序:一种简单而直观的排序算法
java·算法·排序算法
手握风云-7 小时前
Java数据结构第十三期:走进二叉树的奇妙世界(二)
数据结构
小猪咪piggy7 小时前
【数据结构】(12) 反射、枚举、lambda 表达式
java·开发语言·数据结构