学习笔记-线索化二叉树

本文介绍了线索化二叉树的概念,通过在节点中增加leftType和rightType来区分子树和前后继节点。在中序线索化二叉树的过程中,空闲的指针被用来连接前驱和后继节点。中序遍历线索化二叉树时,采用多重循环,从左边界节点开始,沿着后继节点进行遍历。
摘要由CSDN通过智能技术生成

线索化二叉树

线索化二叉树的介绍:
在这里插入图片描述
对于这个普通二叉树来说,节点8,10,14的左右指针是空的,6的右指针是空的,也就是说并没有充分的利用到所有的指针。那么,我们可以对该树线索化,使得空闲的指针被充分利用。
在这里插入图片描述

中序线索化二叉树

在这里插入图片描述

对于一个线索二叉树(如上图),我们让空余节点的左指针指向它的前驱结点,右指针指向它的后继节点。这样一来,该节点的左指针有可能指向它的左子树,也可能指向前驱节点,该节点的右指针有可能指向它的右子树,也有可能指向后继节点。
所以,为了区分,我们在普通树节点的基础上设置leftType和rightType,当0时表示指向左右子树,1时表示指向前驱后继。

//线索化二叉树的节点
class Hero2{
   
    public int no;
    public String name;
    public Hero2 left;
    public Hero2 right;
    //0代表是左子树,1代表是前驱节点
    public int leftType;
    //0代表是右子树,1代表是后继节点
    public int rightType;

    public Hero2(int no, String name) {
   
        this
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值