题目描述
- 一个数组的maxtree定义如下:
- 数组没有重复元素,包括maxtree在内的每个子树都是根节点最大,而且maxtree是二叉树。
- 给定一个没有重复元素的数组arr,要求生成这个数组对应的maxtree,且时间复杂度和空间复杂度都要求为n。
解题方法1
-
一个数组的matree不是唯一的,但是我们要的是符合时间复杂度和空间复杂度的构建方法。
-
那么如何尽快找到每个数左右两侧第一个比他大的数呢?可以使用栈,如果寻找每个数左边第一个比他大的数,每遍历一个新的数就将它与栈顶比较,小于栈顶入栈,大于栈顶让栈顶出栈直到小于当前栈顶或栈空。
-
如【3 1 2】,遍历到3时栈为空说明3没有左边比他大的数,3入栈,遍历到1时1小于3则1左边第一个比他大的数是3,1入栈。遍历到2时1出栈,2入栈说明2左边第一个大于他的数是3。
-
这样我们就可以以比较低的时间复杂度找到每个元素的左右第一个比他大的数,进而找到每个元素的父节点。
-
然后我们要申请两个哈希表,分别存储每个节点左边第一个大的节点和右边第一个大的节点,key为当前节点,value为当前节点左边第一个大的元素节点或右边。
-
最后利用这两个哈希表遍历所有节点找到当前节点父节点,梳理父子节点映射关系,构建二叉树。
public class Test {
public static void main(String[] args) {
int [] arr = {
3,4,5,1,2};
Node root = getmaxtree(arr);
for(Node p=root;p!=null;p=p.left){
System.out.println(p);
}
for(Node p=root;p!=null;p=p.right){
System.out.println