首页 > 其他 > 详细

不同的二叉搜索树

时间:2021-08-20 21:37:52      阅读:24      评论:0      收藏:0      [点我收藏+]

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

示例 1:

输入:n = 3
输出:5
示例 2:

输入:n = 1
输出:1

提示:

1 <= n <= 19

class Solution {
public:
    int numTrees(int n) {
        vector<int> g(n + 1, 0);
        g[0] = 1, g[1] = 1;
        for(int i = 2 ; i <= n; i ++)
        {
            for(int j = 1; j <= i; j ++)
            {
                g[i] += g[j - 1] * g[i - j];
            }
        }
        return g[n];
    }
    //g[i]  i个数字一共可以组成的二叉搜索树的数量
    //f[i, n]  n个数字中, 以第i个数字为根节点组成的二叉搜索数的数量
    //g[i] = (1~n)f[i, n]
    //又f[i, n] = g[i - 1] * g[n - i];与数字无关, 只与长度有关
    //所以 g[i] = (1~n)g[i - 1] * g[n - i]
};

不同的二叉搜索树

原文:https://www.cnblogs.com/jw-zhao/p/15168064.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!