文档详情

二叉树算法应用.ppt

发布:2016-11-26约3.96千字共25页下载文档
文本预览下载声明
* * * * * * * * * * * * * * * * * * * * 二叉树遍历算法应用 遍历演示1 1、统计二叉树中叶子结点的个数 (先序遍历) 2、求二叉树的深度(后序遍历) 3、复制二叉树(后序遍历) 4、建立二叉树的存储结构 遍历演示2 遍历演示3 1、统计二叉树中叶子结点的个数 算法基本思想: 先序(或中序或后序)遍历二叉树,在遍历过程中查找叶子结点,并计数。 由此,需在遍历算法中增添一个“计数”的参数,并将算法中“访问结点”的操作改为:若是叶子,则计数器增1。 void CountLeaf (BiTree T, int count){ if ( T ) { if ((!T-lchild) (!T-rchild)) count++; // 对叶子结点计数 CountLeaf( T-lchild, count); CountLeaf( T-rchild, count); } // if } // CountLeaf 2、求二叉树的深度(后序遍历) 算法基本思想: 从二叉树深度的定义可知,二叉树的深度应为其左、右子树深度的最大值加1。由此,需先分别求得左、右子树的深度,算法中“访问结点”的操作为:求得左、右子树深度的最大值,然后加 1 。 首先分析二叉树的深度和它的左、右子树深度之间的关系。 先序遍历求高度 int Depth (BiTree T ){ // 返回二叉树的深度 if ( !T ) depthval = 0; else { depthLeft = Depth( T-lchild ); depthRight= Depth( T-rchild ); depthval = 1 + (depthLeft depthRight ? depthLeft : depthRight); } return depthval; } 3、复制二叉树 其基本操作为:生成一个结点。 根元素 T 左子树 右子树 根元素 NEWT 左子树 右子树 左子树 右子树 (后序遍历) BiTNode *GetTreeNode(TElemType item, BiTNode *lptr , BiTNode *rptr ){ if (!(T = (BiTNode*)malloc(sizeof(BiTNode)))) exit(1); T- data = item; T- lchild = lptr; T- rchild = rptr; return T; } 生成一个二叉树的结点 (其数据域为item,左指针域为lptr,右指针域为rptr) BiTNode *CopyTree(BiTNode *T) { if (!T ) return NULL; if (T-lchild ) newlptr = CopyTree(T-lchild);//复制左子树 else newlptr = NULL; if (T-rchild ) newrptr = CopyTree(T-rchild);//复制右子树 else newrptr = NULL; newT = GetTreeNode(T-data, newlptr, newrptr); return newT; } // CopyTree A B C D E F G H K ^ D ^ C ^ ^ B ^ H ^ ^ K ^ G ^ F ^ E ^ A 例如:下列二叉树的复制过程如下: newT 4、建立二叉树的存储结构 不同的定义方法相应有不同的存储结构的建立算法 以字符串的形式 根 左子树 右子树 定义一棵二叉树 例如: A B C D 以空白字符“ ”表示 A(B( ,C( , )),D( , )) 空树 只含一个根结点的二叉树 A 以字符串“A ”表示 以下列字符串表示 Status CreateBiTree(BiTree T) { scanf(ch); if (ch== ) T = NULL; else { if (!(T = (BiTNode *)malloc(sizeof(BiTNode)))) exit(OVERFLOW); T
显示全部
相似文档