二叉树的前、中、后序遍历查找

  • 前序遍历查找思路:
  1. 首先把当前结点和查找的id进行比较,如果相等,则找到结果,返回即可;
  2. 定义一个缓存结点,用于存储遍历的结点,如果没找到,判断当前结点的左子树是否为空,不为空进行前序遍历查找递归,之后比较当前得到的结果是否为空,不为空,即表示找到该结点;
  3. 否则,判断当前结点的右子数是否为空,不为空,进行右子数递归前序查找,之后直接返回缓存结点即可;
    //前序遍历查找
    public HeroNode preOrdersearch(int no){
        //比较当前结点是不是
        System.out.println("进入前序遍历!");
        if (this.no == no){
            return this;
        }
        HeroNode resNode = null;//缓存结点
        if(this.left != null){
            resNode = this.left.preOrdersearch(no);
        }
        if (resNode != null){
            return resNode;
        }
        if (this.right != null){
            resNode = this.right.preOrdersearch(no);
        }
        return resNode;//不用判断是否为空,直接返回即可
    }
  • 中序遍历查找思路:
  1. 首先定义一个缓存结点,初始化为空;
  2. 判断当前结点的左子树是否为空,不为空,进行中序递归查找,比较当前结点是否为空,不为空,直接返回,表示找到;
  3. 比较当前结点的id和给定的id是否相等,相等表示找到;
  4. 否则判读当前结点的右子数是否为空,不为空,进行右子数递归查找,直接返回结果即可;
    //中序遍历查找
    public HeroNode infixOrdersearch(int no){

        HeroNode resNode = null;
        if (this.left != null){
            resNode = this.left.infixOrdersearch(no);
        }
        if (resNode != null){
            return resNode;
        }
        System.out.println("进入中序遍历!");
        if (this.no == no){
            return this;
        }
        if (this.right != null){
            resNode = this.right.infixOrdersearch(no);
        }
        return resNode;
    }
  • 后序遍历查找思路:
  1. 首先定义一个缓存结点,初始化为空;
  2. 判断当前结点的左结点是否为空,不为空,进行左子树递归中序遍历查找,判断缓存结点是否为空,不为空表示找到;
  3. 判断当前结点的右子树是否为空,不为空,进行右子树递归中序遍历查找,判断缓存结点是否为空,不为空表示找打;
  4. 比较当前结点的id是否与查找的id相等,相等返回当前结点;
  5. 返回缓存结点;
    //后序查找
    public HeroNode postOrderSearch(int no){
        HeroNode resNode = null;
        if (this.left != null){
            resNode = this.left.postOrderSearch(no);
        }
        if (resNode != null){//说明在左子树找到
            return resNode;
        }
        //如果左子树没有找到,则向右子数进行后序遍历查找
        if (this.right != null){
            resNode = this.right.postOrderSearch(no);
        }
        if (resNode != null){
            return resNode;
        }
        //如果都没找到,就比较当前结点是不是
        System.out.println("进入后序查找!");
        if (this.no == no){
            return this;
        }
        return resNode;
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值