dp[2] = dp[0] * dp[1] (1为根的情况)
+ dp[1] * dp[0] (2为根的情况)
同理可写出 n = 3 的计算方法:
dp[3] = dp[0] * dp[2] (1为根的情况)
+ dp[1] * dp[1] (2为根的情况)
+ dp[2] * dp[0] (3为根的情况)
catalan numbers
class Solution(object):
def numTrees(self, n):
"""
:type n: int
:rtype: int
"""
d=[0 for i in xrange(n+1)]
d[0],d[1]=1,1
for i in xrange(2,n+1):
for j in xrange(i):
d[i]+=d[j]*d[i-1-j]
return d[n]
96. Unique Binary Search Trees
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- https://leetcode.com/problems/unique-binary-search-trees/...
- Given n, how many structurally unique BST's (binary searc...
- Question description My code Test result Solution Use Cat...
- 给出n个数字,能够构建出多少个不同的bst。这道题可以用动态规划来做。那么动态规划重要的是找出状态,以及状态转移方...