【动态规划】96. 不同的二叉搜索树

96. 不同的二叉搜索树

解题思路

  • base case dp[0] = 1 一个空节点 也是一颗二叉树
  • 状态:dp[i] 对于每一个节点i 作为根节点 那么它的二叉搜索树的数量有多少
  • 外层循环:遍历所有的可能节点数目 内存循环遍历所有左右子树组合情况
java 复制代码
class Solution {
    public int numTrees(int n) {
        // base  case

        // dp[0] = 1  

        // 空节点 也是一颗二叉树


        int[] dp = new int[n + 1];

        dp[0] = 1;

        // 状态dp[i]  对于每一个节点i 作为根节点  那么它的二叉搜索树的数量有多少
        for(int i  = 1; i <= n; i++){
            for(int j = 1; j <= i; j++){
                // 左右子树 情况 相乘
                dp[i] += dp[i - j] * dp[j - 1];
            }
        }


        return dp[n];

    }
}
相关推荐
wangchen_05 分钟前
深入理解 C/C++ 强制类型转换:从“暴力”到“优雅”
java·开发语言·jvm
YGGP9 分钟前
【Golang】LeetCode 72. 编辑距离
算法·leetcode
Wang153015 分钟前
Java三大核心热点专题笔记
java
YGGP18 分钟前
【Golang】LeetCode 62. 不同路径
算法·leetcode
潲爺21 分钟前
《Java 8-21 高频特性实战(上):5 个场景解决 50% 开发问题(附可运行代码)》
java·开发语言·笔记·学习
资生算法程序员_畅想家_剑魔24 分钟前
算法-回溯-14
java·开发语言·算法
致Great29 分钟前
大模型对齐核心技术:从第一性原理完整推导 PPO 算法!
人工智能·算法·大模型·agent·智能体
_w_z_j_31 分钟前
二叉树的右视图(BFS或DFS)
算法·深度优先·宽度优先
w_zero_one36 分钟前
Java的Vert.x框架结合Thymeleaf(TH)模板语言
java·开发语言·idea
咸鱼2.044 分钟前
【java入门到放弃】网络
java·开发语言·网络