[96][中等][动态规划] 不同的二叉搜索树
题目描述
给定一个整数 n,求以 1 ... n 为节点组成的二叉搜索树有多少种?
示例:
解题思路
因为题目只要求了数量, 并不需要给出具体的树结构, 个节点对应的二叉搜索树的数量是固定的. 将1到n每个数字依次作为根节点, 小于它的数字组成左子树, 大于它的数字组成右子树, 这样就能递归到左右子树各自的不同组成数量, 两者相乘, 就是在以为根节点时, 可能的组合数量. 将1到n所有根节点对应的组合数量加在一起, 就得到了整数对应的二叉搜索树的组成方案数量.
以上是状态转移的方案, 需要考虑的边际条件是, 当为0或1时, 对应的组成数量都为1.
详细请参考: 不同的二叉搜索树
最后更新于