LeetCode:96.不同的二叉搜索树

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录
LeetCode:96.不同的二叉搜索树

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

示例 1:
输入:n = 3

输出:5

示例 2:

输入:n = 1

输出:1

  • n = 3为例,dp[3] = dp[2] * dp[0] + dp[1] * dp[1] + dp[0] * dp[2],三个结点的二叉排序树的种类 = 左子树为两个结点的种类 * 右子树为0个结点的种类 + 左子树为1个结点的种类 + 右子树为1个结点的种类 + 左子树为0个结点的种类 * 右子树为2个结点的种类
  • 递推公式:dp[i] += dp[j - 1] * dp[i - j]j作为头节点,j - 1作为左子树的结点个数,i - j作为右子树的结点个数
java 复制代码
	public int numTrees(int n) {
        int[] dp = new int[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];
    }
相关推荐
生信探索1 分钟前
SeuratExtend 可视化教程(1):单细胞分析的高颜值绘图指南
算法
BUG创建者2 分钟前
openlayer根据不同的状态显示不同的图层颜色
android·java·javascript
李永奉16 分钟前
C语言-数组:数组(定义、初始化、元素的访问、遍历)内存和内存地址、数组的查找算法和排序算法;
c语言·算法·排序算法
羊锦磊23 分钟前
[java 常用类API] 新手小白的编程字典
java
都叫我大帅哥25 分钟前
TOGAF技术架构阶段全解析:从理论到Java实战,避坑指南附赠!
java
星辰大海的精灵28 分钟前
深入解析 CopyOnWriteArrayList
java·后端·算法
都叫我大帅哥29 分钟前
Java ScopedValue:线程安全的"数据气泡"指南
java
Code季风30 分钟前
深入 Spring IoC 容器:六大关键应用场景助力项目开发
java·spring
这些不会的31 分钟前
iphone手机使用charles代理,chls.pro/ssl 后回车 提示浏览器打不开该网页
java
带刺的坐椅33 分钟前
Solon 集成 LiteFlow:轻量级工作流引擎的极简实践指南
java·solon·liteflow·rule