LeetCode C++ 面试题 04.02. Minimum Height Tree LCCI【Tree/Recursion】简单
发布日期:2021-07-01 02:56:56
浏览次数:3
分类:技术文章
本文共 2352 字,大约阅读时间需要 7 分钟。
Given a sorted (increasing order) array with unique integer elements, write an algorithm to create a binary search tree with minimal height.
Example:
Given sorted array: [-10,-3,0,5,9],One possible answer is: [0,-3,9,-10,null,5],which represents the following tree: 0 / \ -3 9 / / -10 5
题意:给定一个有序整数数组,元素各不相同且按升序排列,编写算法创建一棵高度最小的二叉搜索树。
尽管本题和题目名称相似,但是难度可是大不相同!
顺道一提,本题实际上就是替罪羊树拍扁重建的过程。
解法1 递归先序建树
高度最小的二叉搜索树,显而易见是一棵平衡的二叉搜索树,位于树根的左侧和右侧的节点数量大致相同。如果我们不断将元素插入二叉搜索树中,然后进行AVL调整……时间复杂度绝对爆炸,而且也没有充分利用升序数组这一条件。
正确的做法是,不断递归先序建立二叉搜索树:
- 易知根节点值为
nums[mid]
,建立根节点; - 然后分别递归
nums[0 : mid)
和nums[mid + 1 : )
,建立左右子树; - 这样左右子树的节点数量大致相同,而且也符合二叉搜索树的有序性质。
class Solution { public: void preorderBuild(const vector & nums, int left, int right, TreeNode *&root) { if (left <= right) { int mid = left + (right - left) / 2; root = new TreeNode(nums[mid]); preorderBuild(nums, left, mid - 1, root->left); preorderBuild(nums, mid + 1, right, root->right); } } TreeNode* sortedArrayToBST(vector & nums) { TreeNode *root = nullptr; if (nums.empty()) return root; int n = nums.size(); preorderBuild(nums, 0, n - 1, root); return root; }};
提交后效率如下:
执行用时:20 ms, 在所有 C++ 提交中击败了98.84% 的用户内存消耗:25.4 MB, 在所有 C++ 提交中击败了24.19% 的用户
解法2 非递归先序建树
代码写得稀烂,用到了二级指针,建议看看就好:
*/class Solution { private: struct node { int l, r; TreeNode **ptr; }; //指针的指针,修改指针public: TreeNode* sortedArrayToBST(vector & nums) { TreeNode *root = nullptr; if (nums.empty()) return root; node temp{ 0, static_cast (nums.size() - 1), &root}; queueq; while (temp.l <= temp.r || !q.empty()) { while (temp.l <= temp.r) { int mid = temp.l + (temp.r - temp.l) / 2; *temp.ptr = new TreeNode(nums[mid]); q.push(temp); temp = node{ temp.l, mid - 1, &((*temp.ptr)->left)}; } temp = q.front(); q.pop(); int mid = temp.l + (temp.r - temp.l) / 2; temp = node{ mid + 1, temp.r, &((*temp.ptr)->right)}; } return root; }};
执行结果还行,空间效率倒是大幅提高:
执行用时:28 ms, 在所有 C++ 提交中击败了84.16% 的用户内存消耗:24 MB, 在所有 C++ 提交中击败了84.19% 的用户
转载地址:https://memcpy0.blog.csdn.net/article/details/110010323 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
做的很好,不错不错
[***.243.131.199]2024年04月30日 12时31分48秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Linux shell脚本的字符串截取
2019-05-02
数据库复习(4)
2019-05-02
1小时点击量破千万!阿里巴巴首发:MySQL高级调优笔记!全是技术重点
2019-05-02
这个GItHub上的Java项目开源了 2021最全的Java架构面试复习指南
2019-05-02
Proftpd MySQL [Step by Step]
2019-05-02
EFI Shell 命令参考
2019-05-02
HP-UX oracle RAC 双机实践
2019-05-02
解决SHELL脚本中的export无法生效的问题【转】
2019-05-02
linux中的sh脚本语法【转】
2019-05-02
区别数据结构中的堆栈与内存中的堆栈的个人总结【转】
2019-05-02
c++中冒号(:)和双冒号(::)的用法【转】
2019-05-02
python中各种下划线的含义
2019-05-02
《计算机视觉-一种现代方法(第2版)》读书笔记三:早期视觉(一幅图像)
2019-05-02
《计算机视觉-一种现代方法(第2版)》读书笔记六:应用之图像搜索和检索
2019-05-02
如何撰写高水平的学术论文
2019-05-02
谭浩强《C++面向对象程序设计》知识点总结
2019-05-02
分享一个关于介绍TextCNN和TextRNN的文章
2019-05-02
关于CNN中感受野的理解和计算方法
2019-05-02