版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选文档二叉树的各种算法.txt男人的承诺就像80岁老太太的牙齿,很少有真的。你嗜烟成性的时候,只有三种人会兴奋,医生你的仇人和卖香烟的。/*用函数实现如下二叉排序树算法: (1) 插入新结点 (2) 前序、中序、后序遍历二叉树 (3) 中序遍历的非递归算法 (4) 层次遍历二叉树 (5) 在二叉树中查找给定关键字(函数返回值为成功1,失败0) (6) 交换各结点的左右子树 (7) 求二叉树的深度 (8) 叶子结点数Input第一行:预备建树的结点个数n 其次行:输入n个整数,用空格分隔 第三行:输入待查找的关键字 第四行:输入待查找的关键字 第五行:输入待插入的关键字Output第一行:二叉
2、树的先序遍历序列 其次行:二叉树的中序遍历序列 第三行:二叉树的后序遍历序列 第四行:查找结果 第五行:查找结果 第六行第八行:插入新结点后的二叉树的先、中、序遍历序列 第九行:插入新结点后的二叉树的中序遍历序列(非递归算法) 第十行:插入新结点后的二叉树的层次遍历序列 第十一行第十三行:第一次交换各结点的左右子树后的先、中、后序遍历序列 第十四行第十六行:其次次交换各结点的左右子树后的先、中、后序遍历序列 第十七行:二叉树的深度 第十八行:叶子结点数*/#include "stdio.h"#include "malloc.h"#define TRUE
3、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 BiTNode ElemType data; struct BiTNode *lchild,*
4、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(key<T->data)return SearchBST(T->lchild,key,T,p);else return(SearchBST(T->rchild,key,T,p);Status InsertBST(BiTree &T,ElemTy
5、pe e)BiTree s,p; if(!SearchBST(T,e,NULL,p)s=(BiTree)malloc(sizeof(BiTNode);s->data=e;s->lchild=s->rchild=NULL;if(!p)T=s;else if(e<p->data)p->lchild=s;else p->rchild=s;return TRUE; else return FALSE;Status PrintElement( ElemType e ) / 输出元素e的值printf("%d ", e ); return OK
6、;/ PrintElementStatus PreOrderTraverse( BiTree T, Status(*Visit)(ElemType) ) / 前序遍历二叉树T的递归算法,对每个数据元素调用函数Visit。 /补全代码,可用多个语句 if(T)if(Visit(T->data)if(PreOrderTraverse(T->lchild,Visit)if(PreOrderTraverse(T->rchild,Visit)return OK;return ERROR;else return OK; / PreOrderTraverseStatus InOrderTr
7、averse( BiTree T, Status(*Visit)(ElemType) ) / 中序遍历二叉树T的递归算法,对每个数据元素调用函数Visit。 /补全代码,可用多个语句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)(
8、ElemType) ) / 后序遍历二叉树T的递归算法,对每个数据元素调用函数Visit。 /补全代码,可用多个语句if(T) if(PostOrderTraverse(T->lchild,Visit)if(PostOrderTraverse(T->rchild,Visit)if(Visit(T->data)return OK;return ERROR;else return OK; / PostOrderTraverseStatus Putout(BiTree T) PreOrderTraverse(T,PrintElement);printf("n")
9、;InOrderTraverse(T, PrintElement); printf("n");PostOrderTraverse(T,PrintElement); printf("n"); return OK;/·······················非递归算法struct SqStack BiTree *base; /
10、在栈构造之前和销毁之后,base的值为NULL BiTree *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.top-S.
11、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; *S.top+=e; return OK;Status Pop(SqStack &S,BiTree &e) if(S.top=S.base)return ERROR;e=*-S.top;return OK;Status Sta
12、ckEmpty(SqStack S) / 若栈S为空栈,则返回TRUE,否则返回FALSE if(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;else Pop(S,p);if(!Visit(p->data)return ERROR;p=p->
13、rchild;return OK;/···························层次遍历typedef struct BiTree *base; / 初始化的动态安排存储空间 int front; / 头指针,若队列不空,指向队列头元素 int rear; / 尾指针,若队列不空,指向队列尾元素的下一个位置 SqQue
14、ue;Status InitQueue(SqQueue &Q) Q.base=(BiTree*)malloc(MAXQSIZE*sizeof(BiTree); if(!Q.base)return ERROR; Q.front=Q.rear=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)%
15、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/ 请补全代码 if(Q.front=Q.rear)return ERROR; e=Q.baseQ.front; Q.front=(Q.front+1)%MAXQSIZE; return OK;Status LevelTraverse(BiTree T
16、,SqQueue Q)/层次遍历二叉树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(p->rchild)EnQueue(Q,p->rchild); /右孩子进队 return OK; void Cha
17、nge(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); /计算右子树的深度 int dep2=BTreeDepth(T->rchild)
18、; /返回树的深度 if(dep1>dep2) return dep1+1; else return 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);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;SqQue
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年投资顾问机构合作协议范本6篇
- 2024年度商业空间装修设计与照明工程合同2篇
- 2024年新型配电房土建安装与电气安全检测合同3篇
- 2024年度企业销售人员劳动终止合同3篇
- 2024年室内儿童房墙面安全粉刷服务合同2篇
- 2024版办公楼员工关怀与物业服务合同2篇
- 2024年度股权转让税收协议3篇
- 2024年度腾讯企业邮箱扩展功能服务合同2篇
- 2024年校园内自动售货机租赁协议3篇
- 2024年度体育赛事场地租赁合同模板2篇
- 南宁2024年广西南宁市良庆区教育系统自主招聘教职工笔试历年典型考题及考点附答案解析
- 六年级华杯赛奥数竞赛模拟考试题(30套)
- 法律顾问服务投标方案(完整技术标)
- 2024年9月1日新实施国有企业管理人员处分条例全文学习重点解读条例出台背景特点分析课件
- 客户关系管理-课后练习参考答案 苏朝晖
- JGJT334-2014 建筑设备监控系统工程技术规范
- 2024年网格员考试题库1套
- 生命科学前沿技术智慧树知到期末考试答案章节答案2024年苏州大学
- 高血压护理常规课件
- 心脏介入手术谈话技巧
- 海南省三亚市吉阳区2022-2023学年六年级上学期期末数学试卷
评论
0/150
提交评论