




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
I I部阚七号LIAOCHENGUNIVERSITY,**f-/[2022"2022学年第学期】【一、基本信息】【实验课程】数据结构【设课形式】啦口趣 a【课程学分】4【实验项目】校和队列【项目类型】翱□琮合 瞅计□研趣新□其它 []【项目学时】4【学生姓名】沈凯【学号】2022205377【系别专业】软件开辟【实验班组】级班组台【同组学生】【实验室名】船实麟【实验日期】2022.【报告日期】2022.【二、实验教师对报告的最终评价及处理意见】实验成绩:(涂改无效)指导教师签名:张振领 年月日)±:要将翦领目、实嬲程的獭评定及课程考勤法哪皓知牲,林翦篦即心备案【三、实验预习】实验目的和要求:1、髓掌握二遍螭构,以及娣懒构的麟;2、会定义二叉懒碘构;3、能娜二跑腱立、期等雕,敲破掰颠、懈肺质飘归算法以及蝇融算法。实验内容和原理或者涉及的知识点:自魂与程序实贮用岫各种基本操作,如二叉避健立遍历等。实验条件:具有C露籁开舸境撕算机实验设计方案:好的算法有:1、递归建立二叉林2、轮触遍历二叉桃3、中序递归遍历二叉梯4、后序递归遍历二叉机5、中麻就颠二嘱翦微习成绩(涂改无效) 合格口 不合格口【四、实验过程、数据和实验结果记录】©嫌就、躅嘘作晓腑辘述或起就现②辘过程幡人 随他魏、即斯螺施录。 何加附页)I、辘镂羽赧瞰嬲计族朋伪 c代码如下。typedefstructBiTNode{TelemTypedata;structBiTNode*Ichild,*rchild;}BiTNode,*BiTree;statusCreateBiTree(BiTree&T){〃按先序次序输入二叉机中绐点的(f ,空格表示空树//生成二叉梆的二叉链表存储结构, T为根缰点指针scanf(*'%c",&ch);if(ch==r')T=NULL;else{if(!(T=(BiTNode*)malloc(sizeof(BiTNode))))exit(OVERFLOW);T->data=ch;〃建立根结点CreateBiTree(T->lchild); 〃建立左子树CreateBiTree(T->rchild); 〃建立右子树)returnOK;} //CreateBiTreestatusPrintElement(TelemTypee)(printf(”%c”,e);//输出元素值returnOK;)statusPreorderTraverse(BiTreeT,status(*visit)(TelemTypee)) {//先施历雕殿针为 T的二财if(T) {if(visit(T->data))if(PreorderTraverse(T->Ichild,visit))if(PreorderTraverse(T->rchild,visit))returnOK;returnERROR;}elsereturnOK;//if(T)}//PreorderTraverseStatusInorderTraversel(BiTreeT,Status(*visit)(TElemTypee)){//先序遍历根融指针为 T的二购if(T){if(InorderTraversel(T->lchild,visit))if(visit(T->data))if(InorderTraversel(T->rchild,visit))returnOK;returnERROR;}elsereturnOK;//if(T)}//InorderTraversestatusPostorderTraverse(BiTreeT,status(*visit)(TelemTypee)){〃后序遍历根轴指针为 T的二叉树if(T){if(PostorderTraverse(T->1child,visit))if(PostorderTraverse(T->rchiId,visit))if(visit(T->data))returnOK;returnERROR;}elsereturnOK;//if(T)}//PostorderTraverseStatusInorderTraverse2(BiTreeT,Status(*visit)(TElemTypee))SqStackS;InitStack(S);BiTreep=T;while(p||!StackEmpty(S)){//找到最左下的结点if(p){Push(S,p);p=p->lchild;}//根指针进栈,遍历左子树else{ //®W,访问搬点遍历右子枇Pop(S,p);if(!visit(p->data))returnERROR;p=p->rchild;}//else}//whilereturnOK;}//InOrderTraverse2、将算法触为程就四ftinclude<stdio.h>ftinclude<string.h>ftinclude<stdlib.h>ttdefineLIST_INIT_SIZE10^defineLISTINCREMENT100ftdefineSTACK_INIT_SIZE100^defineSTACKINCREMENT10^defineTRUE1#defineFALSE0#definetrue1#definefalse0ttdefineOK1#defineERROR0^defineINFEASIBLE-1ttdefineOVERFLOW-2^defineOPSETSIZE7^defineMAXQSIZE100#defineNULL0typedefcharTelemType;typedefintStatus;typedefstructBiTNode{TelemTypedata;structBiTNode*lchild,*rchild;}BiTNode,*BiTree;StatusCreateBiTree(BiTree*T);StatusPrintElement(TelemTypee);Statusvisit(TelemTypee);StatusPreorderTraverse(BiTreeT,Status*visit(TelemTypee));StatusInorderTraverse(BiTreeT,Status*visit(TelemTypee));StatusPostorderTraverse(BiTreeT,Status*visit(TelemTypee));intmain(){BiTreeT;printf(Z/Pleaseinputcharacterstocreateatree:\n/z);CreateBiTree(&T);printf("PreorderTraverse:〃);PreorderTraverse(T,visit);printf(/z\nInorderTraverse: ;InorderTraverse(T,visit);printf(/z\nPostorderTraverse:z/);PostorderTraverse(T,visit);return0;}StatusCreateBiTree(BiTree*T)(charch;ch=getchar();if(ch== ')*T=NULL;else(if(!(*T=(BiTNode*)malloc(sizeof(BiTNode))))exit(OVERFLOW);(*T)->data=ch;CreateBiTree(&((*T)->lchiId));CreateBiTree(&((*T)->rchild));)returnOK;}StatusPrintElement(TelemTypee)(printf(〃%c〃,e);returnOK;}Statusvisit(TelemTypee){printf(〃%c〃,e);returnOK;StatusPreorderTraverse(BiTreeT,Status*visit(TelemTypee)){if(T){if(visit(T->data))if(PreorderTraverse(T->lchild,visit))if(PreorderTraverse(T->rchild,visit))returnOK;returnERROR;)returnOK;)StatusInorderTraverse(BiTreeT,Status*visit(TelemTypee)){if(T){if(InorderTraverse(T->lchild,visit))if(visit(T->data))if(InorderTraverse(T->rchild,visit))returnOK;returnERROR;)returnOK;}StatusPostorderTraverse(BiTreeT,Status*visit(TelemTypee))(if(T){if(PostorderTraverse(T->lchild,visit))if(PostorderTraverse(T->rchild,visit))if(visit(T->data))returnOK;returnERROR;)returnOK;}3、编译、链抵运行程度intmain(){BiTreeT;printf(/zPleaseinputcharacterstocreateatree:\n/z);CreateBiTree(&T);printf(z,PreorderTraverse:z/);PreorderTraverse(T,visit);printf(z/\nInorderTraver
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年教师资格证考试(中学综合实践活动)教育知识与能力冲刺押题卷
- 2025年公务员考试行测言语理解专项试卷:逻辑判断与推理高效备考
- 2025年高考生物实验操作专项训练试题解析
- 现代信号处理课件张贤达pdf
- 2026届上海市比乐中学化学高三第一学期期中统考试题含解析
- 2026届湖南长沙县三中高一化学第一学期期中考试模拟试题含解析
- 旅游行业定制旅行项目计划
- 2026届贵州省湄潭县湄江中学化学高三上期末考试试题含解析
- 玉米打药知识培训课件
- 2025年度智能家居系统集成自然人房屋买卖与装修合同
- 中秋节猜灯谜良宵美景解灯谜中秋祝福课件
- 安防行业视频监控系统维护方案
- 初高中政治衔接-知识点讲义
- 全国交通运输行政执法综合管理信息系统考试题库-中(多选题练习)
- 2024年T电梯修理证解析及电梯修理-T证模拟考试题库
- 2024春期国开电大本科《商法》在线形考(形成性考核作业一至四)试题及答案
- (正式版)SHT 3046-2024 石油化工立式圆筒形钢制焊接储罐设计规范
- 2024年四川攀枝花市川投能源攀水电公司招聘笔试参考题库含答案解析
- 全科规培:门诊SOAP病历考核模拟文档
- 三年级上册口算题(可打印)
- 新教师培训讲座课件
评论
0/150
提交评论