力扣96 不同的二叉搜索树 java实现

96.不同的二叉搜索树

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

示例 1:

复制代码
输入:n = 3
输出:5

示例 2:

复制代码
输入:n = 1
输出:1

提示:

  • 1 <= n <= 19

如图所示:

当n为3的时候有以下情况:

当1为头结点的时候,其右子树有两个节点

当2为头结点的时候,其左右子树都只有一个节点

当3为头结点的时候,其左子树有两个节点

元素1为头结点搜索树的数量 = 右子树有2个元素的搜索树数量 * 左子树有0个元素的搜索树数量

元素2为头结点搜索树的数量 = 右子树有1个元素的搜索树数量 * 左子树有1个元素的搜索树数量

元素3为头结点搜索树的数量 = 右子树有0个元素的搜索树数量 * 左子树有2个元素的搜索树数量

由此可推出递归的规律。

java 复制代码
    public static void main(String[] args) { // 测试用
        System.out.println(numTrees(3));
    }

    public static int numTrees(int n) {
        int[] res = new int[n + 1];
        res[0] = 1;
        res[1] = 1;
        for (int i = 2; i <= n; i++) {
            int sum = 0;
            for (int j = 1; j <= i; j++) {
                sum = sum + res[j - 1] * res[i - j];
            }
            res[i] = sum;
        }
        System.out.println(Arrays.toString(res)); // 观测每个数量的不同二叉搜索树
        return res[n];
    }

以上为记录分享用,代码较差请见谅

相关推荐
云烟成雨TD4 分钟前
Spring AI Alibaba 1.x 系列【1】阿里巴巴 AI 生态
java·人工智能·spring
佑白雪乐6 分钟前
LCR 175. 计算二叉树的深度
算法·深度优先
诗人不写诗7 分钟前
spring是如何组织切面的
java·后端·spring
阿Y加油吧13 分钟前
力扣打卡day07——最大子数组和、合并区间
算法
想吃火锅100517 分钟前
【leetcode】105. 从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
圣保罗的大教堂19 分钟前
leetcode 3567. 子矩阵的最小绝对差 中等
leetcode
2401_8318249624 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
靠沿26 分钟前
【优选算法】专题十八——BFS解决拓扑排序问题
算法·宽度优先
cui_ruicheng29 分钟前
C++数据结构进阶:哈希表实现
数据结构·c++·算法·哈希算法·散列表
光电笑映32 分钟前
高阶数据结构之红黑树详解
数据结构