【动态规划-卡特兰数——96.不同的二叉搜索树】

1.题目解析

题目来源

|-------------------------------------------------------------------------------------------------------------------|
| 96.不同的二叉搜索树------力扣 |

测试用例

2.算法原理

1.状态表示

2.状态转移方程

3.初始化

需要用到前面位置的值,则需要初始化dp[0]为1,方便后续的填表

4.填表顺序

从前向后

5.返回值

根据状态表示返回dp[n]

3.实战代码

cpp 复制代码
class Solution {
public:
    int numTrees(int n) 
    {
        vector<int> dp(n+1);
        dp[0] = 1;
        for(int i = 1;i <= n;i++)
        {
            for(int j = 1;j <= i;j++)
            {
                dp[i] += dp[j-1] * dp[i-j];
            }
        }    
        return dp[n];
    }
};

代码解析

相关推荐
PyAIGCMaster5 分钟前
如何编译一个apk,我是新手
深度学习·学习
列逍14 分钟前
深入理解 C++ 智能指针:原理、使用与避坑指南
开发语言·c++
坚持就完事了1 小时前
蓝桥杯中Python常用的库与模块
python·算法
立志成为大牛的小牛1 小时前
数据结构——四十四、平衡二叉树的删除操作(王道408)
数据结构·学习·程序人生·考研·算法
C语言小火车1 小时前
C/C++ 指针全面解析:从基础到进阶的终极指南
c语言·开发语言·c++·指针
Suckerbin1 小时前
一次LeeCode刷题记录:接雨水
算法
Blossom.1182 小时前
RLHF的“炼狱“突围:从PPO到DPO的工业级对齐实战
大数据·人工智能·分布式·python·算法·机器学习·边缘计算
步达硬件2 小时前
【FPGA】FPGA初学者开发板选择及学习路线
学习·fpga开发
wefg12 小时前
【C++】特殊类设计
开发语言·c++
帅中的小灰灰2 小时前
C++编程原型设计模式
开发语言·c++