数据结构_知识点_线索树

1. 线索树填充空指针域规则

(1)若左指针域为空,左指针指向前驱
(2)若右指针域为空,右指针指向后继

2. 如何填充

遍历二叉树的时候,保存上一个结点。

void preOrder(tree t,tree pre)
{
    if(t != NULL)
    {
        visit(t);
        preOrder(t->lchild,t);
        preOrder(t->rchild,t);
    }

    if(t->lchild == NULL)
        t->lchild = pre;
    if(pre->rchild == NULL)
        pre->rchlid = t;
}

3. 遍历线索数的方式

(1) 中序线索树遍历

  • rtag不为0,通过访问rchlid访问后继
  • rtag为0,则先访问结点的右子树,然后不断指向左孩子,直到结点右子树的最左下孩子

(2) 双向线索链表实现中序线索二叉树

Paste_Image.png
  • 建立过程:建立头结点,头结点lchild指向第一个结点,rchild指向中序遍历的最后访问结点;第一个访问结点的前驱指向头结点,最后访问的结点指向头结点

  • 中序遍历:通过头结点lchild找到第一个结点,之后和中序线索二叉树遍历一样

  • 倒中序遍历:通过头结点rchild找到最后一个访问的结点,如果结点ltag为0,说明lchild为前驱,直接访问。如果ltag不为0,则访问其左子树,最右下结点。(从结点的左结点开始,不断指向右结点,直到rtag为0)

(3) 先序线索树遍历

  • 若ltag为0,则访问其左孩子
  • 若ltag不为0,rtag为0,则访问其右孩子
  • 若ltag = 0,rtag = 1,通过rchild访问其后继

(4) 后序线索树遍历
常规方法无法遍历,需要结点添加双亲域或者tag或者使用栈才能进行遍历。因此可以理解为,后序线索二叉树并没什么特别意义,因为遍历后序线索树和后序遍历二叉树并没有简便多少。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 第一章 绪论 什么是数据结构? 数据结构的定义:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 第二章...
    SeanCheney阅读 11,136评论 0 19
  • 1.树(Tree): 树是 n(n>=0) 个结点的有限集。当 n=0 时称为空树。在任意一颗非空树中:有且仅有一...
    ql2012jz阅读 4,832评论 0 3
  • 概念 树是什么 树(Tree)是n(n>=0)个结点的有限集。 n = 0的树是空树。 在任意一棵非空树中: 有且...
    刚刚悟道阅读 10,578评论 1 16
  • 数据结构和算法--二叉树的实现 几种二叉树 1、二叉树 和普通的树相比,二叉树有如下特点: 每个结点最多只有两棵子...
    sunhaiyu阅读 11,623评论 0 14
  • 又到了一年一度放飞自我的时刻,此次的行程让我回忆起了前几年对英文无比排斥且恐慌的自己。喜欢看美剧,但宁愿熬夜等字幕...
    江梦柳_Joy小开酱阅读 5,030评论 9 10

友情链接更多精彩内容