95. Unique Binary Search Trees II
Given an integer n, generate all structurally unique BST’s (binary search trees) that store values 1…n.
For example,
Given n = 3, your program should return all 5 unique BST’s shown below.
题意:
给定一个整数n,生成所有结构不同的的BST(二分搜索树),存储值为1…n。
思路:
这题是 96 Unique Binary Search Trees 的延展,它已经不是让求不同构二叉树的种数,而是直接给出这些不同构的二叉树。
- 每一次都在一个范围内随机选取一个结点作为根。
- 每选取一个结点作为根,就把树切分成左右两个子树,直至该结点左右子树为空。
大致思路如上,可以看出这也是一个可以划分成子问题求解的题目,所以考点是动态规划。
但具体对于本题来说,采取的是自底向上的求解过程。
- 选出根结点后应该先分别求解该根的左右子树集合,也就是根的左子树有若干种,它们组成左子树集合,根的右子树有若干种,它们组成右子树集合。
- 然后将左右子树相互配对,每一个左子树都与所有右子树匹配,每一个右子树都与所有的左子树匹配。然后将两个子树插在根结点上。
- 最后,把根结点放入链表中。
由于1~n是升序列,因此建起来的树天然就是BST。
递归思想,依次选择根节点,对左右子序列再分别建树。
由于左右子序列建树的结果也可能不止一种,需要考虑所有搭配情况。
vector
vector
1 | class Solution { |