给出节点个数求二叉查找树的类型数

思路: 考虑根节点,设对于任意根节点k,有f(k)种树的可能。 比k小的k-1个元素构成k的左子树。则左子树有f(k-1)种情况。 比k大的n-k个元素构成k的右子树。则右子树有f(n-k)种情况。 易知,左右子树相互独立,所以f(k)=f(k-1)*f(n-k)。 综上,对于n,结果为k取1,2,3,...,n时,所有f(k)的和。

代码思路: 根据上述思路可以用简单的递归方法快速解决。

递归方法:

现在考虑非递归解法,用数组记录每个f(i)的值,记f(0)=1,f(1)=1。 根据公式:f(k)=f(k-1)*f(n-k),访问数组中的元素。 循环求和,结果更新到数组中。

我设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


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

推荐阅读更多精彩内容

  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,045评论 0 2
  • 中午在单位我们三吃饭,姚一直纠结另一位同事要借她的饭卡,她借不借呢。闫师傅不停的给她出主意、想说法,然后回头问我的...
    蓝蓝的天沈燕芬阅读 150评论 0 2
  • 1、进程:是在系统中正在运行的一个应用程序。 每个进程之间是独立的,每个进程运行在其专用且受保护的内存空间内。 2...
    LP_ProgramLife阅读 345评论 4 0
  • 离别,承载着悲伤与不舍,父母对我们的爱是无私的,而我们真正回报的又有多少。也许仅仅只是陪伴,只是简单的话语,却可以...
    须弥藏芥子阅读 287评论 0 0
  • 1. Vim的几种模式 正常模式:可以使用快捷键命令,或按:输入命令行。 插入模式:可以输入文本,在正常模式下,按...
    红线路亚湾阅读 17,206评论 0 1