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];
    }
相关推荐
努力进修3 分钟前
【java-数据结构】Java优先级队列揭秘:堆的力量让数据处理飞起来
java·开发语言·数据结构
亚历克斯神3 分钟前
Java 代码质量与静态分析:2026 实战指南
java·spring·微服务
@hhr3 分钟前
使用java对接火山方舟doubao-seedance-1.5-pro 模型进行视频生成
java·python·音视频
廋到被风吹走4 分钟前
【LangChain4j】Java 生态中最灵活、功能最强大的纯 Java 大模型应用开发框架(支持声明式@AiService与复杂RAG/Agent)
java·开发语言·python
艾克杏5 分钟前
初学Java之范型
java·开发语言
heartbeat..6 分钟前
java中常用的几种加密方式
java·开发语言
QQ22792391026 分钟前
Java springboot基于微信小程序的智慧旅游导游系统景点门票酒店预订(源码+文档+运行视频+讲解视频)
java·spring boot·微信小程序·maven·vuejs
小碗羊肉7 分钟前
【从零开始学Java | 第三十九篇】 打印流
java·开发语言
晔子yy7 分钟前
[JAVA探索之路]带你手写多线程实现生产者-消费者模型
java·开发语言
你不是我我7 分钟前
【Java 开发日记】我们来讲一讲 MVCC 的实现原理
java·开发语言