二叉树的基本知识_第1页
二叉树的基本知识_第2页
二叉树的基本知识_第3页
二叉树的基本知识_第4页
二叉树的基本知识_第5页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

二叉树的基本知识数据对象D:D是具有一样特性的数据元素的集合。假设D为空集,那么称为空树;否那么:(1)在D中存在唯一的称为根的数据元素root,(2)当n>1时,其余结点可分为m(m>0)个互不相交的有限集T1,T2,…,Tm,其中每一棵子集本身又是一棵符合本定义的树,称为根root的子树。

数据关系R:结点:结点的度:树的度:叶子结点:分支结点:数据元素+假设干指向子树的分支分支的个数树中所有结点的度的最大值度为零的结点度大于零的结点DHIJM(从根到结点的)途径:孩子结点、双亲结点、兄弟结点、堂兄弟祖先结点、子孙结点结点的层次:树的深度:

由从根到该结点所经分支和结点构成ABCDEFGHIJMKL假设根结点的层次为1,第l层的结点的子树根结点的层次为l+1树中叶子结点所在的最大层次任何一棵非空树是一个二元组Tree=〔root,F〕其中:root被称为根结点,F被称为子树森林森林:是m〔m≥0〕棵互不相交的树的集合ArootBEFKLCGDHIJMF

二叉树或为空树;或是由一个根结点加上两棵分别称为左子树和右子树的、互不交的二叉树组成。ABCDEFGHK根结点左子树右子树EFG两类特殊的二叉树:满二叉树:指的是深度为k且含有2k-1个结点的二叉树。完全二叉树:树中所含的n个结点和满二叉树中编号为1至n的结点一一对应。123456789101112131415abcdefghij二叉树的五种根本形态:NLRLR空树只含根结点NNN右子树为空树左子树为空树左右子树均不为空树二叉树的主要根本操作:查找类插入类删除类Root(T)//求树的根结点查找类:Value(T,cur_e)//求当前结点的元素值Parent(T,cur_e)//求当前结点的双亲结点LeftChild(T,cur_e)//求当前结点的最左孩子RightSibling(T,cur_e)//求当前结点的右兄弟TreeEmpty(T)//断定树是否为空树TreeDepth(T)//求树的深度TraverseTree(T,Visit())//遍历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:在二叉树的第i层上至多有2i-1个结点。(i≥1)性质2:

深度为k的二叉树上至多含2k-1个结点〔k≥1〕性质3:

对任何一棵二叉树,假设它含有n0个叶子结点、n2个度为2的结点,那么必存在关系式:n0=n2+1。。性质4:

具有n个结点的完全二叉树的深度为log2n+1性质5假设对含n个结点的完全二叉树从上到下且从左至右进展1至n的编号,那么对完全二叉树中任意一个编号为i的结点:

(1)假设i=1,那么该结点是二叉树的根,无双亲,否那么,编号为i/2的结点为其双亲结点;

(2)假设2i>n,那么该结点无左孩子,

否那么,编号为2i的结点为其左孩子结点;

(3)假设2i+1>n,那么该结点无右孩子结点,

否那么,编号为2i+1的结点为其右孩子结点二叉树的存储构造二、二叉树的链式存储表示一、二叉树的顺序存储表示#defineMAX_TREE_SIZE100//设二叉树的最大结点数typedefstruct{ElemType*data;//初始化时分配存储空间

intnodeNum;//二叉树中的结点数目}SqBiTree;一、二叉树的顺序存储表示//0号单元存储根结点例如:ABD

012345678910111213ABCDEF1401326(k+1)2-1=2k+1CEF二、二叉树的链式存储表示1.二叉链表2.三叉链表3.双亲链表ADEBCFrootlchilddatarchild结点构造:1.二叉链表typedefstruct{//结点构造TElemTypedata;structBiTNode*lchild,*rchild;//左右孩子指针}BiTNode,*BiTree;lchilddatarchild结点构造:C语言的类型描绘如下:rootADEBCF2.三叉链表parent

lchilddatarchild结点构造:typedefstruct{//结点构造TElemTypedata;structTriTNode*lchild,*rchild;//左右孩子指针structTriTNode*parent;//双亲指针}TriTNode,*TriTree;parentlchilddatarchild结点构造:C语言的类型描绘如下:结点构造:3.双亲链表dataparentABDCEF0B41D42C03E14A-15F36LRTagLRRRL根n=6typedefstruct{//结点构造TElemTypedata;int*parent;//指向双亲的指针charLRTag;//左、右孩子标志域}BPTNodetypedefstruct{//树构造BPTNodenodes[MAX_NODE_SIZE];intnum_node;//树中含结点数目introot;//根结点的位置}BPTree树的三种存储构造一、双亲表示法二、孩子链表表示法三、树的二叉链表(孩子-兄弟〕存储表示法ABCDEFGr=0n=60

A

-11

B

02

C

03

D

04

E

25

F

26

G

5dataparent一、双亲表示法:typedefstructPTNode{Elemdata;intparent;//双亲位置域

}PTNode;

dataparent#defineMAX_TREE_SIZE100结点构造:C语言的类型描绘:typedefstruct{PTNodenodes[MAX_TREE_SIZE];intr,n;//根结点的位置和结点个数

}PTree;树构造:r=0n=6datafirstchildABCDEFG0

A

-11

B

02

C

03

D

04

E

25

F

26

G

4645

123二、孩子链表表示法:-1000224parenttypedefstructCTNode{intchild;structCTNode*nextchild;}*ChildPtr;孩子结点构造:

childnextchildC语言的类型描绘:typedefstruct{Elemdata;ChildPtrfirstchild;//孩子链的头指针

}CTBox;双亲结点构造

datafirstchildtypedefstruct{CTBoxnodes[MAX_TREE_SIZE];intn,r;//结点数和根结点的位置

}CTree;树构造:ABCDEFGrootABCEDFGABCED

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论