[96][中等][动态规划] 不同的二叉搜索树
题目描述
给定一个整数 n,求以 1 ... n 为节点组成的二叉搜索树有多少种?
示例:
输入: 3
输出: 5
解释:
给定 n = 3, 一共有 5 种不同结构的二叉搜索树:
1 3 3 2 1
\ / / / \ \
3 2 1 1 3 2
/ / \ \
2 1 2 3
解题思路
因为题目只要求了数量, 并不需要给出具体的树结构, 个节点对应的二叉搜索树的数量是固定的. 将1到n每个数字依次作为根节点, 小于它的数字组成左子树, 大于它的数字组成右子树, 这样就能递归到左右子树各自的不同组成数量, 两者相乘, 就是在以为根节点时, 可能的组合数量. 将1到n所有根节点对应的组合数量加在一起, 就得到了整数对应的二叉搜索树的组成方案数量.
以上是状态转移的方案, 需要考虑的边际条件是, 当为0或1时, 对应的组成数量都为1.
详细请参考: 不同的二叉搜索树
class Solution:
def numTrees(self, n: int) -> int:
if n < 2:
return 1
dp = [0] * (n + 1)
dp[0], dp[1] = 1, 1
for i in range(2, n + 1):
for j in range(i):
dp[i] += dp[j] * dp[i - j - 1]
return dp[-1]
最后更新于
这有帮助吗?