96. Unique Binary Search Trees

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]
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容