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];
    }
相关推荐
Kerwin要坚持日更1 分钟前
一文讲解Java中的BIO、NIO、AIO之间的区别
java·开发语言
冠位观测者12 分钟前
【Leetcode 每日一题 - 补卡】219. 存在重复元素 II
数据结构·算法·leetcode
因兹菜13 分钟前
[LeetCode]day6 59.螺旋矩阵2
算法·leetcode·矩阵
明月清了个风1 小时前
数据结构与算法学习笔记----容斥原理
笔记·学习·算法
汤姆yu1 小时前
基于Springboot的社区药房管理系统
java·spring boot·后端·社区药房
程思扬1 小时前
Android笔记:android 动态设置backgroundTint
android·java·网络·笔记·android-studio
向上的车轮2 小时前
OpenEuler学习笔记(十五):在OpenEuler上搭建Java运行环境
java·linux·笔记·学习
or77iu_N2 小时前
SpringBoot 中的测试jar包knife4j(实现效果非常简单)
java·开发语言·spring boot·后端·mybatis·jar
codingexpert4042 小时前
Java 抽象类
java·开发语言
晚晚不晚2 小时前
后端token校验流程
java