中序线索二叉树生成(王道)

本文详细介绍了二叉树的线索化算法,包括前序遍历和中序遍历的线索化过程。通过具体的代码实现,展示了如何利用前序和中序遍历将二叉树转换为线索二叉树,使后续的遍历操作更加高效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码:

//王道课程内步骤
void findPreOderPreNode(BiTree &t,BiTree &pre){
    //基础代码与中序遍历二叉树相同
    if (t != NULL){
        findPreOderPreNode(t -> lchild,pre);
        visit(t,pre);
        findPreOderPreNode(t -> rchild,pre);
    }
}
//线索化步骤
void visit(BiTree &t,BiTree &pre){
    //左孩子为空,将指针指向上一个前序结点
    if (t -> lchild == NULL){
        t -> lchild = pre;
        t ->ltag = 1;
    }
    //如果前序结点的右孩子指针为空,将前序结点的右指针指向当前结点
    //此时注意考虑前序结点为空(第一个结点)
    if (pre != NULL && pre ->rchild == NULL) {
        pre->rchild = t;
        pre->rtag = 1;
    }
    pre = t;//,将前序指针后移,进行下一次线索化
}

//书内代码仅将visit函数内的代码复制到visit处即可。

代码
在这里插入图片描述

  • 蓝色为线索化的指针指向
  • 绿色为结点
  • 红色为树的原分支
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值