96.不同的二叉搜索树

96.不同的二叉搜索树

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

示例 1:

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

示例 2:

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

思路

递推公式没想出来。其实关键的一点是以每数字为根节点进行考虑,根据二叉搜索树性质,其左边全是小于根节点的数,右边全是大于根节点的数,且左右子树均为二叉搜索树。不难发现这种规律。

代码

java 复制代码
    public int numTrees(int n) {
        int []dp=new int[n+1];
        dp[0]=1;dp[1]=1;
        for (int i=3;i<=n;i++){
            for (int j=0;j<i;j++){
                dp[i]+=dp[j]*dp[i-j-1];
            }
        }
        return dp[n];
    }
相关推荐
长安er2 小时前
LeetCode 20/155/394/739/84/42/单调栈核心原理与经典题型全解析
数据结构·算法·leetcode·动态规划·
LYFlied7 小时前
【每日算法】LeetCode 5. 最长回文子串(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
qq_433554541 天前
C++区间DP
c++·算法·动态规划
Wuliwuliii2 天前
闵可夫斯基和、需存储的最小状态集
c++·算法·动态规划·闵可夫斯基和
byzh_rc2 天前
[算法设计与分析-从入门到入土] 贪心算法
算法·动态规划
hnjzsyjyj2 天前
洛谷 P2602:[ZJOI2010] 数字计数 ← 数位DP
动态规划·数位dp
小李小李快乐不已2 天前
动态规划理论基础
数据结构·c++·算法·leetcode·动态规划
少许极端2 天前
算法奇妙屋(二十一)-两个数组或字符串的dp问题(动态规划)
算法·动态规划·两个数组或字符串的dp问题
byzh_rc2 天前
[算法设计与分析-从入门到入土] 动态规划
算法·动态规划
IT猿手2 天前
三维动态避障路径规划:基于部落竞争与成员合作算法(CTCM)融合动态窗口法DWA的无人机三维动态避障方法研究,MATLAB代码
算法·matlab·动态规划·无人机·路径规划·动态路径规划