




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 四年级道德与法治下册 第四单元 感受家乡文化 关心家乡发展 12家乡的喜与忧说课稿 新人教版
- 人教版七年级上册历史第四单元17《西晋的短暂统一和北方各族的内迁》说课稿
- 3古诗三首(教学设计)-语文六年级下册统编版
- 回复无根据的抱怨说课稿-2025-2026学年中职专业课-商务英语函电-国际商务-财经商贸大类
- 2025年包头事业单位真题
- Unit2 Section A 1a-2c.第一课时说课稿2025-2026学年人教版八年级英语下册
- 2025年低空经济网络安全防护技术创新与数据跨境流动安全监管报告
- 2025年新能源汽车充电APP广告投放效果分析与优化策略报告
- 2025-2030年低空经济「无人机培训」市场前景分析报告
- XX物业保洁工作监管方案
- 《中国传统文化》第三章
- Unit 3 Faster,Higher,Stronger 大单元说课稿-2024-2025学年高二英语外研版(2019)选择性必修第一册
- 贵州省2024年12月普通高中学业水平合格性考试数学试卷(含答案)
- 政府部门信息科技外包管理规定
- 《大学生创新与创业》课件
- 《就业指导》中职生就业指导全套教学课件
- 【MOOC】园林植物应用设计-北京林业大学 中国大学慕课MOOC答案
- 2024年3D打印混凝土边框叠合板应用技术规程
- 水稻智慧农业解决方案
- caxa电子图板教程
- 非高危行业生产经营单位主要负责人及安全管理人员安全生产知识和管理能力试题及答案
评论
0/150
提交评论