已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验二 二叉树的存储结构及各种运算的实现第一题:#include stdio.h#include malloc.h#define maxsize 66typedef int datatype;typedef struct node datatype data ; struct node *lchild,*rchild; bitree;bitree *Qmaxsize;bitree *creatree()char ch;int front,rear;bitree *root,*s;root=NULL;front=1;rear=0;ch=getchar();while (ch!=#)s=NULL;if(ch!=)s=malloc(sizeof(bitree);s-data=ch;s-lchild=NULL;s-rchild=NULL;rear+;Qrear=s;if(rear=1) root=s;elseif (s&Qfront)if(rear%2=0)Qfront-lchild=s;elseQfront-rchild=s;if(rear%2=1)front+;ch=getchar();return root;preorder(bitree *t) /前if (t)printf( %c ,t-data);preorder(t-lchild);preorder(t-rchild);inorder(bitree *t) /中if (t)inorder(t-lchild);printf( %c ,t-data);inorder(t-rchild);postorder(bitree *t) /后if (t)postorder(t-lchild);postorder(t-rchild);printf( %c ,t-data);int height(bitree *t) /高度int hl,hr;if(!t) return 0;elsehl=height(t-lchild);hr=height(t-rchild);return (hlhr?hl:hr)+1);int leaf(bitree *t) /叶子 static int s; if(t) leaf(t-lchild); leaf(t-rchild); if(t-lchild=NULL&t-rchild=NULL) s=s+1; return s;main()bitree *t;int x,y;printf(输入数据,以#做结尾:n);t=creatree();printf(preorder:t);preorder(t);printf(ninorder:t);inorder(t);printf(npostorder:t);postorder(t);x=height(t);y=leaf(t);printf(n高度:%d,x);printf(n叶子:%d,y); printf(n);第二题:#include #include #define maxsize 40typedef struct node char data; struct node *lchild,*rchild; int ltag,rtag; bitree;bitree *Qmaxsize; /*队列*/bitree *pre=NULL;bitree *creatree() char ch; int front,rear; /*队头、队尾*/ bitree *root,*s; root=NULL; /*空树*/ front=1; rear=0; /*空队*/ ch=getchar(); while(ch!=#) s=NULL; if(ch!=) /*建立新结点*/ s=(bitree *)malloc(sizeof(bitree); s-data=ch; s-lchild=s-rchild=NULL; s-ltag=s-rtag=0; rear+; Qrear=s; /*入队*/ if(rear=1) root=s; else if(s & Qfront) /*孩子、双亲均非空*/ if(rear%2=0) Qfront-lchild=s; else Qfront-rchild=s; if(rear%2=1) front+; /*出队*/ ch=getchar(); return root;/中序遍历;void inorder(bitree *t) if(t) inorder(t-lchild); printf(%c,t-data); inorder(t-rchild); /中序线索划;void INTHREAD(bitree *p)if(p!=NULL) INTHREAD(p-lchild); if(p-lchild=NULL) p-ltag=1; if(p-rchild=NULL) p-rtag=1; if(pre!=NULL) if(pre-rtag=1) pre-rchild=p; if(p-ltag=1) p-lchild=pre; pre=p; INTHREAD(p-rchild); /中序线索二叉树中求中序后继结点;bitree * inordernext (bitree *p) bitree *q; if(p-rtag=1) return p-rchild; else q=p-rchild; while(q-ltag=0) q=q-lchild; return q; /中序遍历;void traverseinthread(bitree *p)if(p!=NULL) while (p-ltag=0 ) p=p-lchild; do printf(%c,p-data); p=inordernext(p); while(p!=NULL); void main() bitree *t; t=creatree(); print
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 烧结制品课程设计
- 画图课程设计
- 骨科患者健康教育内容
- 少儿手工课程设计
- 血压测量中的健康教育策略
- 《GB-T 29428.2-2014地震灾害紧急救援队伍救援行动 第2部分:程序和方法》专题研究报告
- 甲状腺疾病与内分泌系统的关系
- 诗经大雅抑课件
- COPD患者呼吸系统症状的护理管理
- 动物保护区的志愿者写人作文(4篇)
- 药品生产现场管理与过程控制培训ppt
- 风机及塔筒生产全流程检验分析课件
- 网页制作智慧树知到答案章节测试2023年
- 电大专科《建筑制图基础》期末机考试题
- 超星尔雅学习通《大学生心理健康教育(兰州大学版)》2022章节测试答案
- FZ/T 80002-2008服装标志、包装、运输和贮存
- 七巧板题解课件
- 艺术管理学概论-课件
- 男女生正常交往主题班会(50张PPT)
- 铁路典型事故案例分析课件
- 学校卫生防疫工作检查清单(中小学校)
评论
0/150
提交评论