96.不同的二叉搜索树

给你一个整数 n ,求恰由 n 个节点组成且节点值从 1n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。

java 复制代码
class Solution {
    public int numTrees(int n) {
        int[] dp = new int[n+1]; // dp[i] 表示节点数为 i 的不同二叉搜索树的数量。

        dp[0] = 1;
        dp[1] = 1;
        
        for(int i = 2; i <=n; i++)
            for(int j = 1; j <=i; j++)  // j表示根是第 j小的节点。
                // 左子树节点数 = j-1(如果根是第 j小的节点,则比它小的有 j-1个)
                // 右子树节点数 = i-j(比它大的有 i-j个)
                dp[i] += dp[j-1] * dp[i-j];  // 累加不同根的值
        
        return dp[n];
    }
}
相关推荐
To_OC13 小时前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
刘马想放假1 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
05Kevin1 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者2 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠2 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法