Lintcode163 Unique Binary Search Trees solution 题解

【题目描述】

Given n, how many structurally unique BST s (binary search trees) that store values 1...n?

给出n,问由 1...n为节点组成的不同的二叉查找树有多少种?

【题目链接】

www.lintcode.com/en/problem/unique-binary-search-trees/

【题目解析】

设dp[i]表示共有i个节点时,能产生的BST树的个数

n == 0 时,空树的个数必然为1,因此dp[0] = 1

n == 1 时,只有1这个根节点,数量也为1,因此dp[1] = 1

n == 2时,有两种构造方法,dp[2] = dp[0] * dp[1] + dp[1] * dp[0]

n == 3时,构造方法如题目给的示例所示,dp[3] = dp[0] * dp[2] + dp[1] * dp[1] + dp[2] * dp[0]

同时,当根节点元素为 1, 2, 3, 4, 5, ..., i, ..., n时,基于以下原则的BST树具有唯一性:

以i为根节点时,其左子树构成为[0,...,i-1],其右子树构成为[i+1,...,n]构成

因此,dp[i] = sigma(dp[0...k] * dp[k+1...i]) 0 <= k < i - 1

【参考答案】

www.jiuzhang.com/solutions/unique-binary-search-trees/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容