题解 | #有多少个不同的二叉搜索树#

有多少个不同的二叉搜索树

https://www.nowcoder.com/practice/16d23f940a084023b3be6019262589dc

import sys

# for line in sys.stdin:
#     a = line.split()
#     print(int(a[0]) + int(a[1]))

n = int(input())

dp =[0 for i in range(n+1)]
dp[0]=1
# i表示以i个节点有多少个二叉树
for i in range(1,n+1):
  #j表示以j为根节点的二叉树有几颗,以j为根节点将节点分为左边j-1个元素,和右边i-j个元素,j从1开始到i全部遍历
    for j in range(1,i+1):
        dp[i]+= dp[j-1]* dp[i-j]

print(dp[n])

全部评论

相关推荐

点赞 评论 收藏
分享
10-28 15:45
门头沟学院 C++
西南山:海康威视之前不是大规模裁员吗
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务