中序线索化二叉树

1.背景

    1. 由于二叉树的线索化之后,大部分节点的指针指向发生了变化,所以不能使用普通的遍历方法,而是利用其特性
    2. 本程序演示的是中序二叉树的线索化,所以遍历的顺序和二叉树的线索化的顺序一样

2.代码实现

1.节点
public class BinaryTreeNodes {
   
    private int id; // 节点id
    private String name; // 节点名字
    private BinaryTreeNodes left; // 节点的左指针
    private BinaryTreeNodes right; // 节点的右指针

    /*
      这里做一个规定:
            leftType  为0时,指向其左孩子
                      为1时,指向其直接前驱
            rightType 为0时,指向其右孩子
                      为1时,指向其直接后继
     */
    private int leftType;
    private int rightType;

    public BinaryTreeNodes() {
   
    }

    public BinaryTreeNodes(int id, String name) {
   
        this.id = id;
        this.name = name;
    }

    public int getLeftType() {
   
        return leftType;
    }

    public void setLeftType(int leftType) {
   
        this.leftType = leftType;
    }

    public int getRightType() {
   
        return rightType;
    }

    public void setRightType(int rightType) {
   
        this.rightType = rightType;
    }

    public int getId() {
   
        return id;
    }

    public void setId(int id) {
   
        this.id = id;
    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值