美文网首页程序员首页推荐iOS开发
数据结构_知识点_线索树

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

作者: 个革马 | 来源:发表于2017-02-10 09:32 被阅读66次

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或者使用栈才能进行遍历。因此可以理解为,后序线索二叉树并没什么特别意义,因为遍历后序线索树和后序遍历二叉树并没有简便多少。

相关文章

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

    1. 线索树填充空指针域规则 (1)若左指针域为空,左指针指向前驱(2)若右指针域为空,右指针指向后继 2. 如何...

  • 数据结构与算法

    数据结构线性与非线性数组、链表、栈、队列、树、图 树二叉树:顺序,最优、线索、搜索,平衡多路查找树3、排序算法4、...

  • 二叉树复习

    现实生活中树 数据结构中树长这样子 关键知识点 一棵树至少会有一个节点(根节点) 树由节点组成,每个节点的数据结构...

  • 树结构打平为一维数组

    树组件通用知识点:树结构打平为一维数组给定如下数据结构:

  • 2018-11-20

    数据结构 复习了森林转换成二叉树,并写出先序中序序列和后续线索,学习哈夫曼树的构造

  • 数据结构(一)数据结构概述

    数据结构大致包含以下几种存储结构: 线性表,还可以细分为顺序表、链表、栈、队列; 树结构,包括普通树,二叉树,线索...

  • 数据结构

    数据结构大致包含以下几种存储结构: 线性表,还可细分为顺序表、链表、栈和队列; 树结构,包括普通树,二叉树,线索二...

  • 数据结构_树_线索二叉树

    github地址:https://github.com/arkulo56/thought/blob/master/...

  • 数据结构--树

    树 树是很常见而且被广泛利用的数据结构,而且种类繁多,包括一般二叉树、完全二叉树、满二叉树、线索二叉树、二叉排序树...

  • B树和B+树

    王道数据结构知识点整理 B树(多路平衡查找树) 阶:B树中所有结点的孩子结点树的最大值 一棵B树可以是空树,如果不...

网友评论

    本文标题:数据结构_知识点_线索树

    本文链接:https://www.haomeiwen.com/subject/giumittx.html