二叉树的先中后序遍历及相关常用算法_第1页
二叉树的先中后序遍历及相关常用算法_第2页
二叉树的先中后序遍历及相关常用算法_第3页
二叉树的先中后序遍历及相关常用算法_第4页
全文预览已结束

下载本文档

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

文档简介

#include<string.h>#include<stdlib.h>typedefcharT;inti=0; //叶子结点数typedefstructbtnode 〃结点定义{TElement;structbtnode*LChild,*RChild;}BTNode;typedefstructbtree 〃头结点定义{structbtnode*Root;}BTree;BTNode*NewNode() 〃创建空间{BTNode*p=(BTNode*)malloc(sizeof(BTNode));returnp;}voidCreateBT(BTree*Bt) 〃创建一棵空二叉树{Bt->Root=NULL;}voidMakeBT(BTree*Bt,Tx,BTree*Lt,BTree*Rt)〃进行树的建立{BTNode*p=NewNode();p->Element=x;p->LChild=Lt->Root;p->RChild=Rt->Root;Lt->Root=Rt->Root=NULL;Bt->Root=p;}voidVisit(BTNode*p) 〃输出结点*P的元素值{printf("%c",p->Element);}voidPreOrd(void(*Visit)(BTNode*u),BTNode*t) 〃先序遍历递归函数if(t)(*Visit)(t);PreOrd(Visit,t->LChild);PreOrd(Visit,t->RChild);voidInOrd(void(*Visit)(BTNode*u),BTNode*t) 〃中序遍历递归函数{if(t){InOrd(Visit,t->LChild);(*Visit)(t);InOrd(Visit,t->RChild);}}voidPostOrd(void(*Visit)(BTNode*u),BTNode*t) //后序遍历递归函数{if(t){PostOrd(Visit,t->LChild);PostOrd(Visit,t->RChild);(*Visit)(t);}}voidPreOrder(BTreeBt,void(*Visit)(BTNode*u))〃先序遍历{PreOrd(Visit,Bt.Root);}voidInOrder(BTreeBt,void(*Visit)(BTNode*u)) 〃中序遍历{InOrd(Visit,Bt.Root);}voidPostOrder(BTreeBt,void(*Visit)(BTNode*u))〃后序遍历{PostOrd(Visit,Bt.Root);}intSize(BTNode*p) 〃树的结点数与叶子结点数的递归函数{ints,s1,s2;if(!p)return0;elses1=Size(p->LChild);s2=Size(p->RChild);s=s1+s2+1;if(s1==0&&s2==0)//判断是否是叶子节点{i++;printf("%3c",p->Element);returns;}else{returns;}}}intSizeofBT(BTreeBt) 〃树的结点数{returnSize(Bt.Root);}intDepth(BTNode*p) 〃树的高度递归函数{if(!p)return0;elsereturn1+max(Depth(p->LChild),Depth(p->RChild));}intDepthofBT(BTreeBt) //树的高度{returnDepth(BLRoot);}voidBreakBT(BTree*Bt,T*x,BTree*Lt,BTree*Rt) 〃树的拆分{BTNode*p=Bt->Root;if(p){x=p->Element;printf("根数:%c\n",x);Lt->Root=p->LChild;Rt->Root=p->RChild;Bt->Root=NULL;free(p);voidmain(void)BTreea,x,y,z;Te; 〃树的结点的元素intj,k; //树的结点数与高度CreateBT(&a);CreateBT(&x);CreateBT(&y);CreateBT(&z); 〃建立空树MakeBT(&x,'B',&a,&a);MakeBT(&x,'A',&x,&z);printf("遍历算法测试:\n");printf(" -\n");printf("先序遍历测试结果:”);PreOrder(x,Visit);printf("\n中序遍历测试结果:”);InOrder(x,Visit);printf("\n后序遍历测试结果:”);PostOrder(x,Visit);printf("\n树的叶子结点为:");//建立树j=SizeofBT(x);k=DepthofBT(x);printf("\n树的叶子结点数为:%d\n",i);printf("树的结点数为:%d\n"j);printf("树的高度为:%d\n\n\n",k);printf("拆树算法测试:\n");printf(" -\n");BreakBT(&x,&e,&z,&y);printf(" -\n");printf("左孩子:\n");printf("先序遍历测试结果:");PreOrder(z,Visit);printf("\n中序遍历测试结果:");InOrder(z,Visit);printf("\n后序遍历测试结果:”);PostOrder(z,Visit);i=0;printf("\n树的叶子结点为:");//建立树j=SizeofBT(z);k=DepthofBT(z);printf("\n树的叶子结点数为:%d\n",i);printf("树的结点数为:%d\n"j);printf("树的高度为:%d\n\n\n",k);printf(" -\n");printf("右孩子:\n");printf("先序遍历测试结果:");PreOrder(y,Visit);printf("\n中序遍历测试结果:");InOrder(y,Visit);printf("\n后序遍历测试结果:”);PostOrder(y,Visit);i=0;printf("

温馨提示

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

评论

0/150

提交评论