数据结构中的树.ppt
《数据结构中的树.ppt》由会员分享,可在线阅读,更多相关《数据结构中的树.ppt(102页珍藏版)》请在三一办公上搜索。
1、1,树与二叉树,2,树和森林的概念,两种树:自由树与有根树。自由树:一棵自由树 Tf 可定义为一个二元组Tf=(V,E)其中V=v1,.,vn 是由 n(n0)个元素组成的有限非空集合,称为顶点集合。E=(vi,vj)|vi,vj V,1i,jn 是n-1个序对的集合,称为边集合,E 中的元素(vi,vj)称为边或分支。,3,自由树,有根树:一棵有根树 T,简称为树,它是n(n0)个结点的有限集合。当n=0时,T 称为空树;否则,T 是非空树,记作,4,r是一个特定的称为根(root)的结点,它只有直接后继,但没有直接前驱;根以外的其他结点划分为 m(m 0)个互不相交的有限集合T1,T2,T
2、m,每个集合又是一棵树,并且称之为根的子树。每棵子树的根结点有且仅有一个直接前驱,但可以有0个或多个直接后继。,5,树的基本术语,子女:若结点的子树非空,结点子树的根即为该结点的子女。双亲:若结点有子女,该结点是子女双亲。,6,兄弟:同一结点的子女互称为兄弟。度:结点的子女个数即为该结点的度;树中各个结点的度的最大值称为树的度。分支结点:度不为0的结点即为分支结点,亦称为非终端结点。叶结点:度为0的结点即为叶结点,亦称为终端结点。祖先:某结点到根结点的路径上的各个结点都是该结点的祖先。子孙:某结点的所有下属结点,都是该结点的子孙。,7,结点的层次:规定根结点在第一层,其子女结点的层次等于它的层
3、次加一。以下类推。深度:结点的深度即为结点的层次;离根最远结点的层次即为树的深度。,8,高度:规定叶结点的高度为1,其双亲结点的高度等于它的高度加一。有序树:树中结点的各棵子树 T0,T1,是有次序的,即为有序树。无序树:树中结点的各棵子树之间的次序是不重要的,可以互相交换位置。森林:森林是m(m0)棵树的集合。,9,树的抽象数据类型,template class Tree/对象:树是由n(0)个结点组成的有限集合。在/类界面中的 position 是树中结点的地址。在顺序/存储方式下是下标型,在链表存储方式下是指针/型。T 是树结点中存放数据的类型,要求所有结/点的数据类型都是一致的。pub
4、lic:Tree();Tree();,10,BuildRoot(const T/在结点 p 下插入值为 value 的新子女,若插/入失败,函数返回false,否则返回true,11,bool DeleteChild(position p,int i);/删除结点 p 的第 i 个子女及其全部子孙结/点,若删除失败,则返回false,否则返回true void DeleteSubTree(position t);/删除以 t 为根结点的子树 bool IsEmpty();/判树空否,若空则返回true,否则返回false void Traversal(position p);/遍历以 p 为根
5、的子树;,12,二叉树的五种不同形态,L,L,R,R,二叉树(Binary Tree),二叉树的定义一棵二叉树是结点的一个有限集合,该集合或者为空,或者是由一个根结点加上两棵分别称为左子树和右子树的、互不相交的二叉树组成。,13,二叉树的性质,性质1 若二叉树结点的层次从 1 开始,则在二叉树的第 i 层最多有 2i-1 个结点。(i1)证明用数学归纳法性质2 深度为 k 的二叉树最少有 k 个结点,最多有 2k-1个结点。(k1)因为每一层最少要有1个结点,因此,最少结点数为 k。最多结点个数借助性质1:用求等比级数前k项和的公式20+21+22+2k-1=2k-1,14,性质3 对任何一棵
6、二叉树,如果其叶结点有 n0 个,度为 2 的非叶结点有 n2 个,则有n0n21 若设度为 1 的结点有 n1 个,总结点数为n,总边数为e,则根据二叉树的定义,n=n0+n1+n2 e=2n2+n1=n-1 因此,有 2n2+n1=n0+n1+n2-1 n2=n0-1 n0=n2+1,15,定义1 满二叉树(Full Binary Tree)定义2 完全二叉树(Complete Binary Tree)若设二叉树的深度为 k,则共有 k 层。除第 k 层外,其它各层(1k-1)的结点数都达到最大个数,第k层从右向左连续缺若干结点,这就是完全二叉树。,16,性质4 具有 n(n0)个结点的完
7、全二叉树的深度为 log2(n+1)设完全二叉树的深度为k,则有 2k-1-1 n 2k-1 变形 2k-1 n+12k 取对数 k-1 log2(n+1)k 有 log2(n+1)=k,上面k-1层结点数,包括第k层的最大结点数,23-1,24-1,17,性质5 如将一棵有n个结点的完全二叉树自顶向下,同一层自左向右连续给结点编号1,2,n,则有以下关系:若i=1,则 i 无双亲若i 1,则 i 的双亲为i2若2*i=n,则 i 的左子女为 2*i,若2*i+1=n,则 i 的右子女为2*i+1若 i 为奇数,且i!=1,则其左兄弟为i-1,若若 i 为偶数,且i!=n,则其右兄弟为i+1,
8、18,二叉树的抽象数据类型,template class BinaryTree/对象:结点的有限集合,二叉树是有序树public:BinaryTree();/构造函数 BinaryTree(BinTreeNode*lch,BinTreeNode*rch,T item);/构造函数,以item为根,lch和rch为左、右子/树构造一棵二叉树 int Depth();/求树深度 int Size();/求树中结点个数,19,bool IsEmpty();/判二叉树空否?BinTreeNode*Parent(BinTreeNode*t);/求结点 t 的双亲 BinTreeNode*LeftChil
9、d(BinTreeNode*t);/求结点 t 的左子女 BinTreeNode*RightChild(BinTreeNode*t);/求结点 t 的右子女 bool Insert(T item);/在树中插入新元素 bool Remove(T item);/在树中删除元素 bool Find(T/取得结点数据,20,BinTreeNode*getRoot();/取根 void preOrder(void(*visit)(BinTreeNode*t);/前序遍历,visit是访问函数 void inOrder(void(*visit)(BinTreeNode*t);/中序遍历,visit是访问
10、函数 void postOrder(void(*visit)(BinTreeNode*t);/后序遍历,(*visit)是访问函数 void levelOrder(void(*visit)(BinTreeNode*t);/层次序遍历,visit是访问函数;,21,完全二叉树 一般二叉树的顺序表示 的顺序表示,二叉树的顺序表示,22,极端情形:只有右单支的二叉树,23,二叉树结点定义:每个结点有3个数据成员,data域存储结点数据,leftChild和rightChild分别存放指向左子女和右子女的指针。,二叉链表,二叉树的链表表示,24,三叉链表,二叉树的链表表示,每个结点增加一个指向双亲的指
11、针parent,使得查找双亲也很方便。,25,二叉树链表表示的示例,26,二叉树遍历,二叉树的遍历就是按某种次序访问树中的结点,要求每个结点访问一次且仅访问一次。设访问根结点记作 V 遍历根的左子树记作 L 遍历根的右子树记作 R则可能的遍历次序有 前序 VLR 镜像 VRL 中序 LVR 镜像 RVL 后序 LRV 镜像 RLV,27,中序遍历二叉树算法的框架是:若二叉树为空,则空操作;否则中序遍历左子树(L);访问根结点(V);中序遍历右子树(R)。遍历结果 a+b*c-d-e/f,中序遍历(Inorder Traversal),-,-,/,+,*,a,b,c,d,e,f,28,二叉树递归
12、的中序遍历算法,template void BinaryTree:InOrder(BinTreeNode*subTree,void(*visit)(BinTreeNode*t)if(subTree!=NULL)InOrder(subTree-leftChild,visit);/遍历左子树 visit(subTree);/访问根结点 InOrder(subTree-rightChild,visit);/遍历右子树;,29,前序遍历二叉树算法的框架是:若二叉树为空,则空操作;否则访问根结点(V);前序遍历左子树(L);前序遍历右子树(R)。遍历结果-+a*b-c d/e f,前序遍历(Preord
13、er Traversal),-,-,/,+,*,a,b,c,d,e,f,30,二叉树递归的前序遍历算法,template void BinaryTree:PreOrder(BinTreeNode*subTree,void(*visit)(BinTreeNode*t)if(subTree!=NULL)visit(subTree);/访问根结点PreOrder(subTree-leftChild,visit);/遍历左子树PreOrder(subTree-rightChild,visit);/遍历右子树;,31,后序遍历二叉树算法的框架是:若二叉树为空,则空操作;否则后序遍历左子树(L);后序遍历
14、右子树(R);访问根结点(V)。遍历结果 a b c d-*+e f/-,后序遍历(Postorder Traversal),-,-,/,+,*,a,b,c,d,e,f,32,二叉树递归的后序遍历算法,template void BinaryTree:PostOrder(BinTreeNode*subTree,void(*visit)(BinTreeNode*t)if(subTree!=NULL)PostOrder(subTree-leftChild,visit);/遍历左子树PostOrder(subTree-rightChild,visit);/遍历右子树visit(subTree);/访
15、问根结点;,33,template int BinaryTree:Size(BinTreeNode*subTree)const/私有函数:利用二叉树后序遍历算法计算二叉/树的结点个数 if(subTree=NULL)return 0;/空树 else return 1+Size(subTree-leftChild)+Size(subTree-rightChild);,应用二叉树遍历的事例,34,template int BinaryTree:Height(BinTreeNode*subTree)const/私有函数:利用二叉树后序遍历算法计算二叉/树的高度或深度 if(subTree=NULL
16、)return 0;/空树高度为0 else int i=Height(subTree-leftChild);int j=Height(subTree-rightChild);return(i j)?j+1:i+1;,35,利用二叉树前序遍历建立二叉树,以递归方式建立二叉树。输入结点值的顺序必须对应二叉树结点前序遍历的顺序。并约定以输入序列中不可能出现的值作为空结点的值以结束递归,此值在RefValue中。例如用“”或用“-1”表示字符序列或正整数序列空结点。,36,层次序遍历二叉树就是从根结点开始,按层次逐层遍历,如图:,遍历顺序,层次序遍历二叉树的算法,37,这种遍历需要使用一个先进先出的
17、队列,在处理上一层时,将其下一层的结点直接进到队列(的队尾)。在上一层结点遍历完后,下一层结点正好处于队列的队头,可以继续访问它们。算法是非递归的。,38,a,访问a,进队,a出队访问b,进队访问c,进队,b,c,b出队访问d,进队,c,d,c出队访问e,进队,d,e,d出队,e,e出队,39,层次序遍历的(非递归)算法,template void BinaryTree:levelOrder(void(*visit)(BinTreeNode*t)if(root=NULL)return;Queue*Q;BinTreeNode*p=root;visit(p);Q.EnQueue(p);while(
18、!Q.IsEmpty()Q.DeQueue(p);if(p-leftChild!=NULL),40,visit(p-leftChild);Q.EnQueue(p-leftChild);if(p-rightChild!=NULL)visit(p-rightChild);Q.EnQueue(p-rightChild);,41,由二叉树的前序序列和中序序列可唯一地确定一棵二叉树。例,前序序列 A B H F D E C K G 和中序序列 H B D F A E K C G,构造二叉树过程如下:,42,前序序列 A B H F D E C K G,43,如果前序序列固定不变,给出不同的中序序列,可得
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 中的

链接地址:https://www.31ppt.com/p-3787985.html