码迷,mamicode.com
首页 > 其他好文 > 详细

96不同的二查搜索树

时间:2020-07-15 23:51:44      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:二叉搜索树   tree   搜索   特点   print   节点   +=   个数   pre   

# 二叉搜索树的特点是左子树小于根节点,右子树大于根节点。
# 因此当根节点为i的时候,左子树的值为1:i-1,右子树为i+1:n
# 当节点为n的时候所有的能够组成的树为左子树个数乘以右子树个数。
class Solution:
def numTrees(self, n: int) -> int:
dp = [0] * (n + 1)
dp[0] = 1
for index1 in range(1,n + 1):
for index2 in range(1,index1 + 1):
# dp[index2 - 1]代表左子树个数
# dp[index1 - index2]代表右子树个数
dp[index1] += dp[index2 - 1] * dp[index1 - index2]
return dp[n]
A = Solution()
print(A.numTrees(3))

96不同的二查搜索树

标签:二叉搜索树   tree   搜索   特点   print   节点   +=   个数   pre   

原文地址:https://www.cnblogs.com/cong12586/p/13307605.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!