1-8 数组的maxtree

题目描述

  • 一个数组的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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值