leetcode:不同的二叉树

cpp 复制代码
class Solution {
public:
    
    int numTrees(int n) 
    {
        vector<int> dp(n+1);
        dp[0] = 1;
        dp[1] = 1;
        for(int i = 2;i <= n;i++)
        {
            for(int j = 1;j <= i;j++) // 当根节点为j时
            {
                dp[i] += dp[j-1] * dp[i-j];
            }
        }
        return dp[n];
    }
};
/*  dp[i] = i个不同的数组成的二叉搜索数的个数
    假设 i = 5
    当根节点等于 1 时 ,其余数字都比1大,只能在右边 dp[i] += dp[4]
    当根节点等于 2 时,左边有一个1比2小,右边有三个比2大的数字 dp[i] += dp[1] * dp[3]
    当根节点等于 3 时,左边有两个数比3小,右边有两个数比3大的数字 dp[i] += dp[2] * dp[2]
    ...
    直到根节点等于5,左边有4个数字比5小,只能放在5的左边,dp[i] += dp[4]
*/
相关推荐
Z9fish4 分钟前
C语言算法专题总结(一)排序
c语言·算法·排序算法
美式请加冰11 分钟前
模拟的介绍和使用
java·开发语言·算法
云泽80816 分钟前
蓝桥杯算法精讲:贪心算法之区间问题深度剖析
算法·贪心算法·蓝桥杯
tankeven17 分钟前
HJ129 小红的双生数
c++·算法
万能的小裴同学17 分钟前
C++ 简易的FBX查看工具
开发语言·c++·算法
Boop_wu17 分钟前
[Java 算法] 前缀和(2)
算法·哈希算法·散列表
Hello.Reader32 分钟前
深入浅出 Adam 优化算法从直觉到公式
深度学习·算法
识君啊32 分钟前
拆分与合并的艺术·分治思想:Java归并排序深度解析
java·数据结构·算法·排序算法·归并排序·分治
Trouvaille ~33 分钟前
【贪心算法】专题(六):降维打击与错位重构的终极收官
c++·算法·leetcode·面试·贪心算法·重构·蓝桥杯
2301_8008951034 分钟前
dijkstra求最短路径--备考蓝桥杯版
算法