- 2
- 0
- 约1.28万字
- 约 100页
- 2019-01-06 发布于广东
- 举报
数据结构C描述树
Void lorder (bitree * t) { bitree *q[maxsize],*p; // maxsize为最大容量 int f,r; // f,r类似于头尾指针 q[1]=t; f=r=1; while (f=r) { p=q[f]; f++; //出队 cout p-data; if(p -lchild!=NULL) { r++; q[r]=p-1child; } //入队 if (p-rchild!=NULL) { r++; q[r]=p-rchild;} //入队 } } 6.4线索二叉树 6.4.1 线索的概念 通过前面介绍的二叉树可知,遍历二叉树实际上就是将树中所有结点排成一个线性序列(即非线性结构线性化),在这样的线性序列中,很容易求得某个结点在某种遍历下的直接前驱和后继。然而,有时我们希望不进行遍历就能快速找到某个结点在某种遍历下的直接前驱和后继,这样,就应该把每个结点的直接前驱和直接后继记录下来。为了做到这一点,可以在原来的二叉链表结点中,再增加两个指针域,一个指向前驱,一个指向后继,但这样做将会浪费大量存贮单元,存贮空间的利用率相当低(一个结点中有4个指针,1个指左孩子,1个指右孩子,1个指前驱,1个指后继),而原来的左、右孩子域有许多空指针又没有利用起来。为了不浪费存存贮空间,我们利用原有的孩子指针为空时来存放直接前驱和后继,这样的指针称为“线索”,加线索的过程称为线索化,加了线索的二叉树,称为线索二叉树,对应的二叉链表称为线索二叉链表。 在线索二叉树中,由于有了线索,无需遍历二叉树就可以得到任一结点在某种遍历下的直接前驱和后继。但是,我们怎样来区分孩子指针域中存放的是左、右孩子信息还是直接前驱或直接后继信息呢?为此,在二叉链表结点中,还必须增加两个标志域ltag、rtag。 ltag和rtag定义如下: 0 lchild域指向结点的左孩子 ltag= 1 lchild域指向结点在某种遍历下的直 接前驱 0 rchild域指向结点的右孩子 rtag= 1 rchild域指向结点在某种遍历下的直接后继 这样,二叉链表中每个结点还是有5个域,但其中只有2个指针,较原来的4个指针要方便。增加线索后的二叉链表结点结构可描述如下: 2.线索的分类 另外,根据遍历的不同要求,线索二叉树可以分为: (1)前序前驱线索二叉树(只需画出前驱) (2)前序后继线索二叉树(只需画出后继) (3)前序线索二叉树(前驱和后继都要标出) (4)中序前驱线索二叉树(只需画出前驱) (5)中序后继线索二叉树(只需画出中序后继) (6)中序线索二叉树(中序前驱和后继都要标出) (7)后序前驱线索二叉树(只需画出后序前驱) (8)后序后继线索二叉树(中需画出后序后驱) (9)后序线索二叉树(后前驱和后继都要标出) 6.4.2线索的描述 1.结点数据类型描述 struct Hbitree { elemtype data; int ltag ,rtag; //左、右标志域 Hbitree *lchild, *rchild; } ; 2.线索的画法 在二叉树或二叉链表中,若左孩子为空,则画出它的直接前驱,右孩子为空时,则画出它的直接后继,左右孩子不为空时,不需画前驱和后继。这样就得到了线索二叉树或线索二叉链表。 前序序列为:ABCD 对于图6-7所示二叉树,用二叉链表形式描述见图6-8。 对于一棵二叉树,若采用二叉链表存贮时,当二叉树为非完全二叉树时,比较方便,若为完全二叉树时,将会占用较多存贮单元(存放地址的指针)。若一棵二叉树有n个结点,采用二叉链表作存贮结构时,共有2n个指针域,其中只有n-1个指针指向左右孩子,其余n+1个指针为空,没有发挥作用,被白白浪费掉了,(当然后面介绍的线索可利用它)。 (2)二叉链表的数据类型 二叉链表的数据类型描述如下: struct bitree { elemtype data ; //结点数据类型 bitree *lchild, *rchild;} //定义左、右孩子为指针型 (3)二叉链表的建立 为了后面遍历二叉树方便,先介绍建立二叉链表的算法(假设elemtype 为char型)。
您可能关注的文档
最近下载
- 2025年下半年时事政治选择题(一).docx VIP
- 2026年徐州幼儿师范高等专科学校单招《数学》试卷附完整答案详解(名校卷).docx VIP
- 广东省房屋建筑工程竣工验收技术资料统一用表(2025版最新).docx
- 非煤露天矿山安全设施设计编写提纲.doc VIP
- 2026年兴安职业技术学院单招综合素质考试题库附答案详解.docx VIP
- 昆明寻甸渝昆高铁在建项目“8·18”较大导梁机倾覆事故调查报告.PDF VIP
- 建筑材料采购合同包退条款范本.docx VIP
- 2026年兴安职业技术学院单招综合素质考试题库参考答案详解.docx VIP
- 混凝土蒸汽加热法计算.doc VIP
- 2023年广东省东莞市中考语文试卷真题(含答案详解).docx
原创力文档

文档评论(0)