二叉树的各种算法_第1页
二叉树的各种算法_第2页
二叉树的各种算法_第3页
二叉树的各种算法_第4页
二叉树的各种算法_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

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

文档简介

1、二叉树的各种算法、 txt 男人的承诺就像 80 岁老太太的牙齿 , 很少有真的。您嗜烟成性的时 候, 只有三种人会高兴 , 医生 您的仇人与卖香烟的。/* 用函数实现如下二叉排序树算法 :(1) 插入新结点(2) 前序、中序、后序遍历二叉树(3) 中序遍历的非递归算法(4) 层次遍历二叉树(5) 在二叉树中查找给定关键字 ( 函数返回值为成功 1, 失败 0)(6) 交换各结点的左右子树(7) 求二叉树的深度(8) 叶子结点数Input第一行 : 准备建树的结点个数 n第二行:输入n个整数,用空格分隔第三行 : 输入待查找的关键字第四行 : 输入待查找的关键字第五行 : 输入待插入的关键字O

2、utput第一行 : 二叉树的先序遍历序列第二行 : 二叉树的中序遍历序列第三行 : 二叉树的后序遍历序列第四行 : 查找结果第五行 : 查找结果第六行 第八行 : 插入新结点后的二叉树的先、中、序遍历序列第九行 : 插入新结点后的二叉树的中序遍历序列 ( 非递归算法 )第十行 : 插入新结点后的二叉树的层次遍历序列第十一行 第十三行 : 第一次交换各结点的左右子树后的先、中、后序遍历序列第十四行 第十六行 : 第二次交换各结点的左右子树后的先、中、后序遍历序列第十七行 : 二叉树的深度第十八行 : 叶子结点数*/#include stdio 、 h#include malloc 、 h#de

3、fine TRUE 1#define FALSE 0#define OK 1#define ERROR 0#define INFEASIBLE -1#define OVERFLOW -2typedef int Status;typedef int KeyType;#define STACK_INIT_SIZE 100 / 存储空间初始分配量#define STACKINCREMENT 10 / 存储空间分配增量#define MAXQSIZE 100typedef int ElemType;typedef struct BiTNodeElemType data;struct BiTNode *

4、lchild,*rchild;/ 左右孩子指针 BiTNode,*BiTree;Status SearchBST(BiTree T,KeyType key,BiTree f,BiTree &p)if(!T)p=f;return FALSE;else if(key=T-data)p=T;return TRUE;else if(keydata)return SearchBST(T-lchild,key,T,p);else return(SearchBST(T-rchild,key,T,p);Status InsertBST(BiTree &T,ElemType e)BiTree s,p; if(!

5、SearchBST(T,e,NULL,p) s=(BiTree)malloc(sizeof(BiTNode); s-data=e;s-lchild=s-rchild=NULL; if(!p)T=s;else if(edata)p-lchild=s;else p-rchild=s; return TRUE;else return FALSE;Status PrintElement( ElemType e ) / 输出元素 e 的值 printf(%d , e );return OK;/ PrintElementStatus PreOrderTraverse( BiTree T, Status(*

6、Visit)(ElemType) ) Visit 。/前序遍历二叉树T的递归算法,对每个数据元素调用函数/ 补全代码 , 可用多个语句if(T) if(Visit(T-data) if(PreOrderTraverse(T-lchild,Visit) if(PreOrderTraverse(T-rchild,Visit)return OK; return ERROR;else return OK; / PreOrderTraverseStatus InOrderTraverse( BiTree T, Status(*Visit)(ElemType) )/ 中序遍历二叉树 T 的递归算法 , 对

7、每个数据元素调用函数/ 补全代码 , 可用多个语句if(T)if(InOrderTraverse(T-lchild,Visit)if(Visit(T-data) if(InOrderTraverse(T-rchild,Visit) return OK;return ERROR;else return OK; / InOrderTraverseStatus PostOrderTraverse( BiTree T, Status(*Visit)(ElemType) ) / 后序遍历二叉树 T 的递归算法 , 对每个数据元素调用函数/ 补全代码 , 可用多个语句if(T)if(PostOrderTr

8、averse(T-lchild,Visit) if(PostOrderTraverse(T-rchild,Visit) if(Visit(T-data)return OK; return ERROR;else return OK;Visit 。Visit 。 / PostOrderTraverseStatus Putout(BiTree T)PreOrderTraverse(T,PrintElement);printf(n);InOrderTraverse(T, PrintElement);printf(n);PostOrderTraverse(T,PrintElement);printf(n

9、);return OK;/ 非递归算法struct SqStackBiTree *base; / BiTree *top; / int stacksize; /在栈构造之前与销毁之后 ,base 的值为 栈顶指针当前已分配的存储空间 , 以元素为单位NULL; / 顺序栈Status InitStack(SqStack &S)S 、 base=(BiTree *)malloc(STACK_INIT_SIZE*sizeof(BiTree);if(!S 、 base)return ERROR;S 、 top=S 、 base;S 、 stacksize=STACK_INIT_SIZE;return

10、 OK;Status Push(SqStack &S,BiTree e)if(S 、 top-S 、 base)=S 、 stacksize)base,(SS 、 base=(BiTree*)realloc(S 、 stacksize+STACKINCREMENT)*sizeof(BiTree);if(!S、 base)return ERROR;S、 top=S 、 base+S、 stacksize;S、 stacksize+=STACKINCREMENT;*S 、 top+=e;return OK;Status Pop(SqStack &S,BiTree &e)if(S、 top=S 、

11、base)return ERROR;e=*-S 、 top;return OK;Status StackEmpty(SqStack S) / 若栈S为空栈,则返回TRUE否则返回FALSEif(S 、 top-S 、 base=0)return TRUE;else return FALSE;Status InOrderTraverse1(BiTree T,Status(*Visit)(ElemType e),SqStack S)BiTree p;InitStack(S);p=T;while(p|!StackEmpty(S)if(p)Push(S,p);p=p-lchild;elsePop(S,

12、p);if(!Visit(p-data)return ERROR;p=p-rchild;return OK;/ 层次遍历typedef structBiTree *base; / 初始化的动态分配存储空间int front; / 头指针 , 若队列不空 , 指向队列头元素int rear; / 尾指针 , 若队列不空 , 指向队列尾元素的下一个位置SqQueue;Status InitQueue(SqQueue &Q)Q 、base=(BiTree*)malloc(MAXQSIZE*sizeof(BiTree);if(!Q 、 base)return ERROR;Q 、front=Q 、 re

13、ar=0;return OK;int QueueLength(SqQueue Q)/ 返回 Q 的元素个数/ 请补全代码return(Q、 rear-Q 、 front+MAXQSIZE)%MAXQSIZE;Status EnQueue(SqQueue &Q,BiTree e)/插入元素e为Q的新的队尾元素/ 请补全代码if(Q、rear+1)%MAXQSIZE=Q、front)return ERROR;Q 、baseQ 、rear=e;Q 、rear=(Q 、 rear+1)%MAXQSIZE;return OK;Status DeQueue(SqQueue &Q,BiTree &e)/若队

14、列不空,则删除Q的队头元素,用e返回其值,并返回0K;否则返回ERROR/ 请补全代码if(Q 、 front=Q 、 rear)return ERROR;e=Q 、 baseQ、front;Q 、front=(Q 、 front+1)%MAXQSIZE;return OK;Status LevelTraverse(BiTree T,SqQueue Q)/层次遍历二叉树InitQueue(Q);BiTree p;p=T;if(T)EnQueue(Q,T);/ printf(%d,QueueLength(Q); while(QueueLength(Q)!=0)左孩子进队右孩子进队DeQueue(

15、Q,p); / 根结点出队 printf(%d ,p-data); / 输出数据 if(p-lchild)EnQueue(Q,p-lchild); / if(p-rchild)EnQueue(Q,p-rchild); /return OK;void Change(BiTree T)BiTNode *p;if(T)p=T-lchild;T-lchild=T-rchild;T-rchild=p;Change(T-lchild);Change(T-rchild);/ return OK;int BTreeDepth(BiTree T)/求由 BT 指针指向的一棵二叉树的深度/int dep1,dep

16、2;if(T!=NULL)/ 计算左子树的深度int dep1=BTreeDepth(T-lchild);/ 计算右子树的深度int dep2=BTreeDepth(T-rchild);/ 返回树的深度 if(dep1dep2) return dep1+1; elsereturn dep2+1;else return 0;/ 叶子结点数Status yezhi(BiTree T,SqQueue Q)int i=0;InitQueue(Q);BiTree p;p=T;if(T)EnQueue(Q,T);/ printf(%d,QueueLength(Q); while(QueueLength(Q

17、)!=0) DeQueue(Q,p); if(p-lchild)EnQueue(Q,p-lchild); if(p-rchild)EnQueue(Q,p-rchild); if(!p-lchild&!p-rchild)i+;return i;int main() / 主函数SqStack S;SqQueue Q,Q3;BiTree T=NULL,f,p;int i,n,e,a,b,c;scanf(%d,&n);for(i=0;in;i+)scanf(%d,&e);InsertBST(T,e); scanf(%d,&a);scanf(%d,&b);scanf(%d,&c);Putout(T); printf(%dn,Se

温馨提示

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

评论

0/150

提交评论