满二叉树(fullbinarytree):所有非叶子结点度为2,叶子结点在同一层次一完全二叉树(completebinarytree):深度h,h-1为满二叉树,h层的结点都集中在左侧一二叉树的基本操作)10)910510111213141581112(a)满二叉树(b)完全二叉树6中国科学技术大学ypb@ustc.edu.cn
ypb@ustc.edu.cn 6 中国科学技术大学 •LeftSibling(T,e) •RightSibling(T,e) •InsertChild(T,p,LR,C) •DeleteChild(T,p,LR) •PreOrderTraverse(T,visit()) •InOrderTraverse(T,visit()) •PostOrderTraverse(T,visit()) •Traverse(T) •InitBiTree(&T) •DestroyBiTree(&T) •CreateBiTree(&T,definition) •BiTreeEmpty(T) •BiTreeDepth(T) •Parent(T,e) •LeftChild(T,e) •RightChild(T,e) – 满二叉树(full binary tree):所有非叶子结点度为2, 叶子结点在同一层次 – 完全二叉树(complete binary tree):深度h,h-1为 满二叉树,h层的结点都集中在左侧 – 二叉树的基本操作
6.2.2二叉树的几个基本性质性质1在二叉树的第层的结点个数最多2(i-1)性质2深度为k的二叉树的最大结点数为2k-1,度性质3任一二叉树T,如果其叶子结点数为no,为2的结点数为n2,则no=nz+1no+n,+n2=n=2n,+n,+1·性质4具有n个结点的完全二叉树深度为Llogn+1[log(n+1) I中国科学技术大学ypb@ustc.edu.cn
ypb@ustc.edu.cn 7 中国科学技术大学 • 性质1 在二叉树的第i层的结点个数最多2 (i-1) • 性质2 深度为k的二叉树的最大结点数为2 k -1 • 性质3 任一二叉树T,如果其叶子结点数为n0, 度 为2的结点数为n2,则n0=n2+1 n0+n1+n2=n=2n2+n1+1 • 性质4 具有n个结点的完全二叉树深度为logn+1 log(n+1) 6.2.2二叉树的几个基本性质
·性质5女如果对一个有n个结点的完全二叉树T的结点按层序(从第一层到第[logn]+1层,层内从左到右)从1开始编号,则对任意一个编号为i(1<=i<=n)的结点有:一如果i=1,则该结点是二叉树的根,无双亲;如果i>1,则其双亲结点Parent(i)的编号为[i/2]一如果2>n,则编号为i的结点没有左孩子,为叶子结点;否则其左孩子LChild(i)的编号为2i一如果2+1>n,则编号为i的结点没有右孩子;否则其右孩子RChild(i)的编号为2i+18中国科学技术大学ypb@ustc.edu.cn
ypb@ustc.edu.cn 8 中国科学技术大学 • 性质5 如果对一个有n个结点的完全二叉树T的结 点按层序(从第一层到第[logn]+1层,层内从左到 右)从1开始编号,则对任意一个编号为i(1<=i<=n) 的结点有: – 如果i=1,则该结点是二叉树的根,无双亲;如果 i>1,则其双亲结点Parent(i)的编号为[i/2] – 如果2i>n,则编号为i 的结点没有左孩子,为叶子结 点;否则其左孩子LChild(i)的编号为2i – 如果2i+1>n,则编号为i 的结点没有右孩子;否则其 右孩子RChild(i)的编号为2i+1
6.2.3二叉树的存储结构顺序存储结构Const MAXSIZE= 100A3524234506061()完全二叉树(6)一般二叉树中国科学技术大学ypb@ustc.edu.cn
ypb@ustc.edu.cn 9 中国科学技术大学 • 顺序存储结构 Const MAXSIZE=100 typedef struct{ ElemType *data; int nodenum; }SqBiTree 6.2.3二叉树的存储结构
S00·链式存亻ABNo_二叉销一域,找父亲必须人AEAAFA一三叉rent四个域,找父AAAHA(a)二叉链表rootrchildd:结点结构IClchildrchilddataAEAAOD(a)结点1结点结构T(b)三叉链表10ypb@ustc.edu.cn中国科学技术大学
ypb@ustc.edu.cn 10 中国科学技术大学 • 链式存储结构 – 二叉链表 包涵data,lchild,rchild三个域,找父亲 必须从根开始 – 三叉链表 包涵data,lchild,rchild,parent四个域, 找父亲容易 typedef struct BiTNode{ ElemType data; struct BiTNode *lchild,*rchild[,*parent]; }BiTNode,*BiTree;