二叉树的各种算法.docx

上传人:苏美尔 文档编号:11681401 上传时间:2021-08-30 格式:DOCX 页数:18 大小:17.18KB
返回 下载 相关 举报
二叉树的各种算法.docx_第1页
第1页 / 共18页
二叉树的各种算法.docx_第2页
第2页 / 共18页
二叉树的各种算法.docx_第3页
第3页 / 共18页
二叉树的各种算法.docx_第4页
第4页 / 共18页
二叉树的各种算法.docx_第5页
第5页 / 共18页
点击查看更多>>
资源描述

《二叉树的各种算法.docx》由会员分享,可在线阅读,更多相关《二叉树的各种算法.docx(18页珍藏版)》请在三一文库上搜索。

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

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

3、0#define OK 1#define ERROR 0#define INFEASIBLE -1 #define OVERFLOW -2typedef int Status;typedef int KeyType;2 / 15#define STACK_INIT_SIZE 100存储空间初始分配量/#define STACKINCREMENT 10存储空间分配增量/#define MAXQSIZE 100typedef int ElemType;typedef struct BiTNodeElemType data;struct BiTNode *lchild,*rchild;/ 左右孩子指

4、针 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(!SearchBST(T,e,NULL,p)s=

5、(BiTree)malloc(sizeof(BiTNode);3 / 15s-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(*Visit)(ElemType) ) / 前

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

8、isit)if(PostOrderTraverse(T-rchild,Visit)if(Visit(T-data)return OK;return ERROR;else return OK; / PostOrderTraverseStatus Putout(BiTree T)PreOrderTraverse(T,PrintElement);printf( );InOrderTraverse(T, PrintElement);printf();PostOrderTraverse(T,PrintElement);printf();return OK;/非递归算法struct SqStack6 /

9、15BiTree *base; / 在栈构造之前和销毁之后, base 的值为 NULLBiTree *top; / 栈顶指针int stacksize; / 当前已分配的存储空间,以元素为单位; / 顺序栈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 OK;Status Push(SqStack &S,BiTree e)if(S.t

10、op-S.base)=S.stacksize)S.base=(BiTree*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(BiTree);if(!S.base)return ERROR;S.top=S.base+S.stacksize;S.stacksize+=STACKINCREMENT;7 / 15*S.top+=e;return OK;Status Pop(SqStack &S,BiTree &e)if(S.top=S.base)return ERROR;e=*-S.top;return OK;Status StackEmpty(

11、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;8 / 15elsePop(S,p);if(!Visit(p-data)return ERROR;p=p-rchild;return OK;/层次遍

12、历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.rear=0;9 / 15return OK;int QueueLength(SqQueue Q)/ 返回 Q 的元素个数/ 请补全代码retur

13、n(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)/若队列不空,则删除Q的队头元素,用e返回其值,并返回OK;否则返回 ERROR/ 请补全代码10 / 15if(Q.front=Q.rear

14、)return ERROR;e=Q.baseQ.front;Q.front=(Q.front+1)%MAXQSIZE;return OK;Status LevelTraverse(BiTree T,SqQueue 理欢遍历二叉树InitQueue(Q);BiTree p;p=T;if(T)EnQueue(Q,T);/ printf(%d,QueueLength(Q);while(QueueLength(Q)!=0)DeQueue(Q,p); / 根结点出队printf(%d ,p-data); / 输出数据if(p-lchild)EnQueue(Q,p-lchild); / 左孩子进队 if(

15、p-rchild)EnQueue(Q,p-rchild); / 右孩子进队 return OK; 11 / 15void 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,dep2;if(T!=NULL)/ 计算左子树的深度int dep1=BTreeDepth(T-lchild);/ 计算右子树的深度12

16、/ 15int 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)!=0)DeQueue(Q,p);13 / 15if(p-lchild)EnQueue(Q,p-lchild);if(p-rc

17、hild)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,SearchBST(T,a,f,p);14 / 15printf(%dn,SearchBST(T,b,f,p);InsertBST(T,c);Putout(T);InOrderTraverse1(T, PrintElement,S); printf();LevelTraverse(T,Q);printf();Change(T);Putout(T);Change(T);Putout(T);printf(%d,BTreeDepth(T);printf();printf(%d,yezhi(T,Q3);printf();return OK;/main15 / 15

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1