1.题目
https://leetcode-cn.com/problems/unique-binary-search-trees/
2.方法一:动态规划
分析
代码
class Solution {
public int numTrees(int n) {
int[] G=new int[n+1];
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];
}
}
复杂度
时间复杂度 : O(n²),其中 n 表示二叉搜索树的节点个数。G(n)函数一共有 n个值需要求解,每次求解需要 O(n)的时间复杂度,因此总时间复杂度为O(n²)。
空间复杂度:O(n)。存放G数组。
结果
3.方法二:卡特兰数 数学
分析
卡特兰数 详解(可惜我还是不怎么懂)
介绍:catalan 百度百科
代码
class Solution {
public int numTrees(int n) {
// 提示:我们在这里需要用 long 类型防止计算过程中的溢出
long C = 1;
for (int i = 0; i < n; ++i) {
C = C * 2 * (2 * i + 1) / (i + 2);
}
return (int) C;
}
}
复杂度
空间复杂度O(1)