Medium!
题目描述:
给定一个整数 n,生成所有由 1 ... n 为节点所组成的二叉搜索树。
示例:
输入: 3 输出: [ [1,null,3,2], [3,2,null,1], [3,1,null,null,2], [2,1,3], [1,null,2,null,3] ] 解释: 以上的输出对应以下 5 种不同结构的二叉搜索树: 1 3 3 2 1 / / / 3 2 1 1 3 2 / / 2 1 2 3
解题思路:
这种建树问题一般来说都是用递归来解,这道题也不例外,划分左右子树,递归构造。至于递归函数中为啥都用的是指针,是参考了http://fisherlei.blogspot.com/2013/03/leetcode-unique-binary-search-trees-ii.html,若不用指针,全部实例化的话会存在大量的对象拷贝,要调用拷贝构造函数,具体我尚且不太懂,感觉挺言之有理,不明觉厉。
C++解法一:
1 class Solution { 2 public: 3 vector<TreeNode *> generateTrees(int n) { 4 if (n == 0) return {}; 5 return *generateTreesDFS(1, n); 6 } 7 vector<TreeNode*> *generateTreesDFS(int start, int end) { 8 vector<TreeNode*> *subTree = new vector<TreeNode*>(); 9 if (start > end) subTree->push_back(NULL); 10 else { 11 for (int i = start; i <= end; ++i) { 12 vector<TreeNode*> *leftSubTree = generateTreesDFS(start, i - 1); 13 vector<TreeNode*> *rightSubTree = generateTreesDFS(i + 1, end); 14 for (int j = 0; j < leftSubTree->size(); ++j) { 15 for (int k = 0; k < rightSubTree->size(); ++k) { 16 TreeNode *node = new TreeNode(i); 17 node->left = (*leftSubTree)[j]; 18 node->right = (*rightSubTree)[k]; 19 subTree->push_back(node); 20 } 21 } 22 } 23 } 24 return subTree; 25 } 26 };