数据结构ppt第六章树和二叉树.ppt
《数据结构ppt第六章树和二叉树.ppt》由会员分享,可在线阅读,更多相关《数据结构ppt第六章树和二叉树.ppt(188页珍藏版)》请在三一办公上搜索。
1、第六章树和二叉树,数据结构可分为线性结构和非线性结构两大类。前面几章主要研究的是线性结构。一般的,线性结构只能用来描述数据元素之间的线性顺序关系,而很难反映元素之间的层次(分支)关系。本章将要讨论一种非线性数据结构,所谓非线性结构是指在结构中至少存在一个数据元素,它具有两个或两个以上的直接后继或直接前驱。树形结构,是一类非常重要的非线性数据结构,它用于描述数据元素之间的层次关系。树形结构在客观世界中广泛存在,如人类社会的族谱和各种社会组织机构都可用树来形象表示。经常用到的两种结构是树和二叉树。本章先介绍树、二叉树的定义、性质及存储结构,重点讨论二叉树的存储结构及其各种操作,并研究树和森林与二叉
2、树之间的转换关系,最后介绍树的应用。,引 言,内容提要,6.1 树的定义和基本术语6.2 二叉树6.3 遍历二叉树和线索二叉树6.4 树和森林6.6 赫夫曼树及其应用小结,6.1 树的定义 和基本术语,树(Tree)是包含n(n0)个结点的有限集。在任意一棵非空树中:(1)有且仅有一个特定的称为根(Root)的结点;(2)当n1时,其余的结点可分为m(m0)个互不相交的子集T1,T2,T3Tm,其中每个子集又是一棵树,并称其为子树(Subtree)。树也可以这样定义:树是由根结点和若干棵子树构成的。可以看出,在树的定义中用了递归的概念,即在树的定义中又用到树的定义,它道出了树的固有特性,因此递
3、归算法是树结构算法的显著特点。,树的定义,上图(a)是只有一个根结点的树;图(b)是有13个结点的树,其中A是根,其余结点分成三个互不相交的子集:T1=B,E,F,K,L,T2=C,G,T3=D,H,I,J,M;T1、T2和T3都是根A的子树,且本身也是一棵树。例如T1,其根为B,其余结点分为两个互不相交的子集;T11=E,K,L,T12=F。T11和T12都是B的子树。而T11中E是根结点,K和L是E的两棵互不相交的子树,其本身又是只有一个根结点的树。,数据对象 D:,D是具有相同特性的数据元素的集合。,若D为空集,则称为空树。否则:(1)在D中存在唯一的称为根的数据元素root;(2)当n
4、1时,其余结点可分为m(m0)个互 不相交的有限集T1,T2,Tm,其中每一 棵子集本身又是一棵符合本定义的树,称为根root的子树。,数据关系 R:,ADT Tree,基本操作:,查 找 类,插 入 类,删 除 类,Root(T)/求树的根结点,查找类:,Value(T,cur_e)/求当前结点的元素值,Parent(T,cur_e)/求当前结点的双亲结点,LeftChild(T,cur_e)/求当前结点的最左孩子,RightSibling(T,cur_e)/求当前结点的右兄弟,TreeEmpty(T)/判定树是否为空树,TreeDepth(T)/求树的深度,TraverseTree(T,V
5、isit()/遍历,InitTree(&T)/初始化置空树,插入类:,CreateTree(&T,definition)/按定义构造树,Assign(T,cur_e,value)/给当前结点赋值,InsertChild(&T,&p,i,c)/将以c为根的树插入为结点p的第i棵子树,ClearTree(&T)/将树清空,删除类:,DestroyTree(&T)/销毁树的结构,DeleteChild(&T,&p,i)/删除结点p的第i棵子树,树的表示方法有四种,各用于不同的目的。(1)直观表示法:就是一棵树的直观表示。(2)广义表示法:下图(a)是以广义表的形式表示的,根作为由子树森林组成的表的名
6、字写在表的左边。树的形式化表示法主要用于树的理论描述。(3)凹入表示法:下图(b)用的是凹入表示法(类似书的编目)。树的凹入表示法主要用于树的屏幕和打印显示。(4)嵌套集合表示法:参见P120图6.2。表示方法的多样性,正说明了树结构在日常生活中及计算机程序设计中的重要性。一般来说,分等级的分类方案都可用层次结构来表示,也就是说,都可产生一个树结构。,树的表示形式,A,B,C,D,E,F,G,H,I,J,M,K,L,A(B(E,F(K,L),C(G),D(H,I,J(M),T1,T3,T2,树根,例如:,基 本 术 语,结点:,结点的度:,树的度:,叶子结点:,分支结点:,数据元素及若干指向子
7、树的分支,拥有的子树数,树中所有结点的度的最大值,度为零的结点,度大于零的结点,D,H,I,J,M,(从根到结点的)路径:,结点的层次:,树的深度:,由从根到该结点所经分支和结点构成,A,B,C,D,E,F,G,H,I,J,M,K,L,假设根结点的层次为1,第l 层的结点的子树根结点的层次为l+1,树中叶子结点所在的最大层次,孩子结点:结点子树的根双亲结点:孩子结点的直接前驱兄弟结点:同一双亲的孩子间堂兄弟:双亲在同一层的结点祖先结点:从根到该结点所经分支的所有结点子孙结点:以某结点为根的子树中的任一结点,()有确定的根;()树根和子树根之间为有向关系。,有向树:,有序树:,子树之间存在确定的
8、次序关系。,无序树:,子树之间不存在确定的次序关系。,任何一棵非空树是一个二元组 Tree=(root,F)其中:root 被称为根结点 F 被称为子树森林,森林:,是m(m0)棵互不相交的树的集合,A,root,B,C,D,E,F,G,H,I,J,M,K,L,F,对比树型结构和线性结构的结构特点,线性结构,树型结构,第一个数据元素(无前驱),根结点(无前驱),最后一个数据元素(无后继),多个叶子结点(无后继),其它数据元素(一个前驱、一个后继),其它数据元素(一个前驱、多个后继),6.2 二 叉 树,6.2.1 二叉树的定义 二叉树(Binary Tree)或为空树,或是由一个根结点加上两棵
9、分别称为左子树和右子树的、互不相交的二叉树组成。,A,B,C,D,E,F,G,H,K,根结点,左子树,右子树,二叉树的五种基本形态:,N,空树,只含根结点,N,N,N,L,R,R,右子树为空树,L,左子树为空树,左右子树均不为空树,抽象数据类型二叉数定义,ADT BinaryTree 数据对象 D:D是具有相同特性的数据元素的集合。数据关系R:若D=,则R=,称BinaryTree为空二叉树;若D,则R=H,H是如下二元关系:(1)在D中存在唯一的称为根的数据元素root,它在关系H下无前驱;(2)若Droot,则存在Droot=DL,Dr,DLDr=,(3)若DL,则DL存在唯一的数据元素x
10、L,有 H;且存在DL上的关系HLH;若Dr,则Dr存在唯一的数据元素xr,有 H;且存在Dr上的关系HrH,H=,,HL,Hr;(4)(DL,HL)是一棵符合本定义的二叉树,称为根root的左子树,(Dr,Hr)是一棵符合本定义的二叉树,称为根root的右子树,,二叉树的主要基本操作:,查 找 类,插 入 类,删 除 类,Root(T);Value(T,e);Parent(T,e);LeftChild(T,e);RightChild(T,e);LeftSibling(T,e);RightSibling(T,e);BiTreeEmpty(T);BiTreeDepth(T);PreOrderTr
11、averse(T,Visit();InOrderTraverse(T,Visit();PostOrderTraverse(T,Visit();LevelOrderTraverse(T,Visit();,InitBiTree(,ClearBiTree(,6.2.2 二叉树 的性质,性质1:在二叉树的第 i 层上至多有2i-1 个结点。(i1),用归纳法证明:归纳基:归纳假设:归纳证明:,i=1 层时,只有一个根结点:2i-1=20=1;,假设对所有的 j,1 j i,命题成立;,二叉树上每个结点至多有两棵子树,则第 i 层的结点数=2i-2 2=2i-1。,性质 2:深度为 k 的二叉树上至多含
12、 2k-1 个结点(k1)。,证明:,基于上一条性质,深度为 k 的二叉树上的结点数至多为 20+21+2k-1=2k-1。,性质 3:对任何一棵二叉树,若它含有n0 个叶子结点、n2 个度为 2 的结点,则必存在关系式:n0=n2+1。,证明:,设 二叉树上结点总数 n=n0+n1+n2又 二叉树上分支总数 b=n1+2n2 而 b=n-1=n0+n1+n2-1由此,n0=n2+1。,两类特殊的二叉树:,满二叉树:指的是深度为k且含有2k-1个结点的二叉树。,完全二叉树:树中所含的 n 个结点和满二叉树中编号为 1 至 n 的结点一一对应。,1,2,3,4,5,6,7,8,9,10,11,1
13、2,13,14,15,a,b,c,d,e,f,g,h,i,j,性质 4:具有 n 个结点的完全二叉树的深度为 log2n+1。,证明:,设完全二叉树的深度为 k 则根据第二条性质得 2k-1 n 2k 即 k-1 log2 n k 因为 k 只能是整数,因此,k=log2n+1。,性质 5:,若对含 n 个结点的完全二叉树从上到下且从左至右进行 1 至 n 的编号,则对完全二叉树中任意一个编号为 i 的结点:(1)若 i=1,则该结点是二叉树的根,无双亲,否则,编号为 i/2 的结点为其双亲结点;(2)若 2in,则该结点无左孩子,否则,编号为 2i 的结点为其左孩子结点;(3)若 2i+1n
14、,则该结点无右孩子结点,否则,编号为2i+1 的结点为其右孩子结点。,6.2.3 二叉树的存储结构,二、二叉树的链式 存储结构,一、二叉树的顺序 存储结构,#define MAX_TREE_SIZE 100/二叉树的最大结点数typedef TElemType SqBiTreeMAX_ TREE_SIZE;/0号单元存储根结点SqBiTree bt;,一、二叉树的顺序存储结构,按照顺序存储结构的定义,在此约定,用一组地址连续的存储单元依次自上而下、自左至右存储二叉树上的结点元素。因此,必须把结点安排成一个适当的线性序列,使得结点在这个序列中的相互位置能反映出结点之间的逻辑关系。在一棵有n个结点
15、的完全二叉树中,从树根起,自上层到下层,每层从左到右地给结点编号,就能得到一个足以反映整个二叉树结构的线性序列,如下图所示。,二叉树的顺序存储结构,练习:,A,B,C,D,E,F,A B D C E F,0 1 2 3 4 5 6 7 8 9 10 11 12 13,1,4,0,13,2,6,二、二叉树的链式存储表示,1.二叉链表,2三叉链表,3双亲链表,4线索链表,A,D,E,B,C,F,root,lchild data rchild,结点结构:,1.二叉链表,二叉链表,A,B,C,D,E,F,二叉树,typedef struct BiTNode/结点结构 TElemType data;st
16、ruct BiTNode*lchild,*rchild;/左右孩子指针 BiTNode,*BiTree;,lchild data rchild,结点结构:,C 语言的类型描述如下:,A,D,E,B,C,F,root,2三叉链表,parent lchild data rchild,结点结构:,typedef struct TriTNode/结点结构 TElemType data;struct TriTNode*lchild,*rchild;/左右孩子指针 struct TriTNode*parent;/双亲指针 TriTNode,*TriTree;,parent lchild data rchi
17、ld,结点结构:,C 语言的类型描述如下:,0123456,data parent,结点结构:,3双亲链表,LRTag,LRRRL,typedef struct BPTNode/结点结构 TElemType data;int*parent;/指向双亲的指针 char LRTag;/左、右孩子标志域 BPTNode typedef struct BPTree/树结构 BPTNode nodesMAX_TREE_SIZE;int num_node;/结点数目 int root;/根结点的位置 BPTree,二叉树的遍历,6.3 遍历二叉树和线索二叉树,一、问题的提出,二、先左后右的遍历算法,三、算
18、法的递归描述,四、中序遍历算法的非递归描述,五、遍历算法的应用举例,如何按着某条搜索路径巡访二叉树中的每个结点,使得每个结点均被访问一次,而且仅被访问一次。,一、问题的提出,“访问”的含义可以很广,如:输出结点的信息等。,“遍历”是任何类型均有的操作,对线性结构而言,只有一条搜索路径(因为每个结点均只有一个后继),故不需要另加讨论。而二叉树是非线性结构,,每个结点有两个后继,则存在如何遍历即按什么样的搜索路径遍历的问题。,二叉树的遍历方法 二叉树由根、左子树、右子树三部分组成 二叉树的遍历可以分解为:访问根,遍历左子树和遍历右子树,令:L:遍历左子树 D:访问根结点 R:遍历右子树 有六种遍历
19、方法:DLR,LDR,LRD,DRL,RDL,RLD,约定先左后右,有三种遍历方法:DLR、LDR、LRD,分别称为 先序遍历、中序遍历、后序遍历,58,先序遍历(DLR)若二叉树非空(1)访问根结点;(2)先序遍历左子树;(3)先序遍历右子树;,先序遍历序列:,例:先序遍历右图所示的二叉树(1)访问根结点A(2)先序遍历左子树:即按DLR的顺序遍历左子树(3)先序遍历右子树:即按DLR的顺序遍历右子树,A,B,C,D,F,G,E,二、先左后右的遍历算法,59,中序遍历(LDR)若二叉树非空(1)中序遍历左子树(2)访问根结点(3)中序遍历右子树,中序遍历序列:,例:中序遍历右图所示的二叉树(
20、1)中序遍历左子树:即按LDR的顺序遍历左子树(2)访问根结点 A(3)中序遍历右子树:即按LDR的顺序遍历右子树,D,B,C,G,F,A,E,60,后序遍历(LRD)若二叉树非空(1)后序遍历左子树(2)后序遍历右子树(3)访问根结点,后序遍历序列:,例:后序遍历右图所示的二叉树(1)后序遍历左子树:即按LRD的顺序遍历左子树(2)后序遍历右子树:即按LRD的顺序遍历右子树(3)访问根结点 A,D,G,C,E,A,F,B,61,后序遍历序列:,中序遍历序列:,先序遍历序列:,例:先中序遍历序遍历、中序遍历、后序遍历下图所示的二叉树,前缀表达式,中缀表达式,后缀表达式,-,+,a,*,b,-,
21、c,d,/,e,f,a,+,b,*,c,-,d,-,e,/,f,a,b,c,d,-,*,+,e,f,/,-,练习:求下列二叉链表和二叉树的三种遍历次序,A,B,C,D,E,F,G,H,K,这实际上是先序遍历的递归定义,我们知道递归定义包括两个部分:1)基本项(也叫终止项);2)递归项,若二叉树非空(1)访问根结点;(2)先序遍历左子树(3)先序遍历右子树;,先序遍历递归定义递归项,上面介绍了三种遍历方法,显然是用递归的方式给出的三种遍历方法,以先序为例:先序遍历(DLR)的定义:,该定义隐含着若二叉树为空,结束,三、算法的递归描述,上面先序遍历的定义等价于:若二叉树为空,结束 基本项(也叫终止
22、项)若二叉树非空 递归项(1)访问根结点;(2)先序遍历左子树(3)先序遍历右子树;,下面给出先序、中序、后序遍历递归算法,为了增加算法的可读性,这里对书上算法作了简化,没有考虑访问结点出错的情况(即我们假设调用函数visit()访问结点总是成功的。,2 中序遍历递归算法void InOrderTraverse(BiTree T,Status(*Visit)(TElemType e)/采用二叉链表存贮二叉树,visit()是访问结点的函数。本算法中序遍历以为根结点指针的二叉树,对每个数据元素调用函数Visit()if(T)/若二叉树为空,结束返回/若二叉树不为空,遍历左子树,访问根结点,遍历右
23、子树 InOrderTraverse(T-lchild,Visit);Visit(T-data);InOrderTraverse(T-rchild,Visit);/InOrderTraverse,你能写出后序遍历递归算法了吧?,3 后序遍历递归算法void PostOrderTraverse(BiTree T,Status(*Visit)(TElemType e)/采用二叉链表存贮二叉树,visit()是访问结点的函数。本算法中序遍历以为根结点指针的二叉树,对每个数据元素调用函数Visit()if(T)/若二叉树为空,结束返回/若二叉树不为空,遍历左子树,遍历右子树,访问根结点 PostOrd
24、erTraverse(T-lchild,Visit);PostOrderTraverse(T-rchild,Visit);Visit(T-data);/PostOrderTraverse,任何一棵二叉树都可以将它的外部轮廓用一条线绘制出来,我们将它称为二叉树的包线,这条包线对于理解二叉树的遍历过程很有用。,G H,D E F,B C,A,四、中序遍历算法的非递归描述,Status InOrderTraverse(BiTree T,Status(*Visit)(ElemType)/采用二叉链表存储结构,Visit是对数据元素操作的应用/函数.中序遍历二叉树T的非递归算法,对每个数据元素调/用函数
25、Visit。InitStack(S);Push(S,T);/根指针进栈 while(!StackEmpty(S)while(GetTop(S,p)/InOrderTraverse,Status InOrderTraverse(BiTree T,Status(*Visit)(ElemType)/采用二叉链表存储结构,Visit是对数据元素操作的应用/函数。中序遍历二叉树T的非递归算法,对每个数据元素调/用函数Visit。InitStack(S);p=T;while(p|!StackEmpty(S)if(p)Push(S,p);p=p-lchild;/非空指针进栈,继续左进 else/上层指针退栈
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 ppt 第六 二叉
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-6296826.html