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

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

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])

全部评论

相关推荐

不愿透露姓名的神秘牛友
04-16 16:26
我的工资够买几件上千的衣服?是时候反思了
菜鸟CV程序猿:国内这都不是老板,是奴隶主
点赞 评论 收藏
分享
03-11 21:46
西北大学 Java
河和静子:这只是实习工资,我学长北大通班博一的,他同学被这家天天发邮件让他去实习,一个月10w
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务