LeetCode(95): 不同的二叉搜索树 II
2023-09-14 09:01:22 时间
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 };
相关文章
- LeetCode每日一题-7:有效的括号
- ☆打卡算法☆LeetCode 198. 打家劫舍 算法解析
- LeetCode 704 二分查找 C++ 解法
- LeetCode 235. 二叉搜索树的最近公共祖先
- leetcode-234. 回文链表
- Baozi Leetcode solution 2353. Design a Food Rating System
- leetcode 35. 搜索插入位置 js 实现
- LeetCode周赛330,开工第一天从刷LeetCode开始
- 用Js刷LeetCode拿offer-经典高频40题
- LeetCode - #63 不同路径 II
- LeetCode - #72 编辑距离(Top 100)
- LeetCode | 搜索插入位置
- 每日一道leetcode:11. 盛最多水的容器
- LeetCode——二叉树的非递归遍历