![2023年C++二叉树基本操作实验报告_第1页](http://file4.renrendoc.com/view/92e315455edb083de15d8ad9b61befdb/92e315455edb083de15d8ad9b61befdb1.gif)
![2023年C++二叉树基本操作实验报告_第2页](http://file4.renrendoc.com/view/92e315455edb083de15d8ad9b61befdb/92e315455edb083de15d8ad9b61befdb2.gif)
![2023年C++二叉树基本操作实验报告_第3页](http://file4.renrendoc.com/view/92e315455edb083de15d8ad9b61befdb/92e315455edb083de15d8ad9b61befdb3.gif)
![2023年C++二叉树基本操作实验报告_第4页](http://file4.renrendoc.com/view/92e315455edb083de15d8ad9b61befdb/92e315455edb083de15d8ad9b61befdb4.gif)
![2023年C++二叉树基本操作实验报告_第5页](http://file4.renrendoc.com/view/92e315455edb083de15d8ad9b61befdb/92e315455edb083de15d8ad9b61befdb5.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一、实验目的选择二叉链式存储结构作为二叉树的存储结构,设计一个程序实现二叉树的基本操作(涉及建立、输出、前序遍历、中序遍历、后序遍历、求树高、记录叶子总数等)实验开发环境Windows8.1中文版MicrosoftVisualStudio6.0三、实验内容程序的菜单功能项如下:1------建立一棵二叉树2------前序遍历递归算法3------前序遍历非递归算法4------中序遍历递归算法5------中序遍历非递归算法6------后序遍历递归算法7------后序遍历非递归算法8------求树高9------求叶子总数10-----输出二叉树11-----退出四、实验分析1、建立一棵二叉树2、输入二叉树各节点数据cout<<"请按对的顺序输入二叉树的数据:";cin.getline(t,1000);//先把输入的数据输入到一个t数组3、递归前序遍历voidBL1(ECS_data*t){if(NULL!=t){cout<<t->data<<",";BL1(t->l);BL1(t->r);}}4、非递归前序遍历ﻩvoidpreOrder2(ECS_data*t)ﻩ{ stack<ECS_data*>s; ﻩECS_data*p=t;ﻩﻩwhile(p!=NULL||!s.empty()) ﻩ{ﻩﻩﻩwhile(p!=NULL) {ﻩ ﻩﻩcout<<p->data<<""; ﻩﻩ s.push(p);ﻩﻩ p=p->l;ﻩﻩ } if(!s.empty()) {ﻩ ﻩp=s.top(); ﻩﻩ s.pop(); ﻩ p=p->r;ﻩﻩﻩ} }ﻩ}5、递归中序遍历voidBL2(ECS_data*t){if(NULL!=t){BL2(t->l);cout<<t->data<<",";BL2(t->r);}}6、非递归中序遍历ﻩvoidinOrder2(ECS_data*t)//非递归中序遍历 {ﻩ stack<ECS_data*>s; ﻩECS_data*p=t;ﻩﻩwhile(p!=NULL||!s.empty())ﻩ {ﻩ while(p!=NULL)ﻩﻩ { ﻩﻩﻩs.push(p); ﻩﻩ p=p->l;ﻩ }ﻩ if(!s.empty())ﻩ ﻩ{ ﻩ p=s.top(); ﻩcout<<p->data<<""; ﻩ s.pop(); ﻩ ﻩp=p->r; ﻩ}ﻩﻩ}ﻩ}7、递归后序遍历voidBL3(ECS_data*t){if(NULL!=t){BL3(t->l);BL3(t->r);cout<<t->data<<",";}}8、非递归后序遍历 voidpostOrder3(ECS_data*t)ﻩ{ stack<ECS_data*>s;ﻩ ECS_data*cur;//当前结点ﻩ ECS_data*pre=NULL;//前一次访问的结点 ﻩs.push(t);ﻩ while(!s.empty())ﻩﻩ{ cur=s.top(); ﻩﻩif((cur->l==NULL&&cur->r==NULL)|| ﻩ ﻩ(pre!=NULL&&(pre==cur->l||pre==cur->r))) ﻩ {ﻩ ﻩﻩcout<<cur->data<<"";//假如当前结点没有孩子结点或者孩子节点都已被访问过 ﻩﻩs.pop(); ﻩ pre=cur; ﻩﻩ}ﻩﻩﻩelseﻩ ﻩ{ ﻩﻩif(cur->r!=NULL)ﻩ ﻩ s.push(cur->r);ﻩ ﻩﻩif(cur->l!=NULL) ﻩ s.push(cur->l); } }ﻩ}9、求树高ﻩintHeight(ECS_data*t) {if(t==NULL)return0;ﻩﻩelse {ﻩﻩﻩintm=Height(t->l); ﻩﻩintn=Height(t->r); ﻩ return(m>n)?(m+1):(n+1);ﻩﻩ} }10、ﻩ求叶子总数intCountLeaf(ECS_data*t) { staticintLeafNum=0;//叶子初始数目为0,使用静态变量ﻩﻩif(t)//树非空ﻩﻩ{ﻩ ﻩif(t->l==NULL&&t->r==NULL)//为叶子结点ﻩ ﻩLeafNum++;//叶子数目加1ﻩ else//不为叶子结点 ﻩ { ﻩﻩCountLeaf(t->l);//递归记录左子树叶子数目ﻩ ﻩ CountLeaf(t->r);//递归记录右子树叶子数目 }ﻩ }ﻩﻩreturnLeafNum; }五、运营结果附:完整程序源代码://二叉树链式存储的实现#include<iostream>#include<cstring>#include<stack>usingnamespacestd;structECS_data//先定义好一个数据的结构{chardata;ECS_data*l;ECS_data*r;};classECS{private://intlevel;//树高intn;//表达有多少个节点数intn1;//表达的是数组的总长度值,(涉及#),由于后面要进行删除判断ECS_data*temp[1000];public:ECS_data*root;ECS()//初始化{ECS_data*p;chart[1000];inti;intfront=0,rear=1;//front表达有多少个节点,rear表达当前插入的点的父母cout<<"请按对的顺序输入二叉树的数据:";cin.getline(t,1000);//先把输入的数据输入到一个t数组//cout<<t<<""<<endl;intn1=strlen(t);//测量数据的长度n=0;for(i=0;i<n1;i++){if(t[i]!='#'){p=NULL;if(t[i]!=',')//满足条件并开辟内存{n++;p=newECS_data;p->data=t[i];p->l=NULL;p->r=NULL;}front++;temp[front]=p;if(1==front){root=p;}else{if((p!=NULL)&&(0==front%2)){temp[rear]->l=p;//刚开始把这里写成了==}if((p!=NULL)&&(1==front%2)){temp[rear]->r=p;}if(1==front%2)rear++;//就当前的数据找这个数据的父母}}}}~ECS()//释放内存{inti;for(i=1;i<=n;i++)if(temp[i]!=NULL)deletetemp[i];}voidJS()//记录节点的个数{ints;s=n;cout<<"该二叉树的节点数为:"<<s<<endl;}voidBL1(ECS_data*t)//递归前序遍历{if(NULL!=t){cout<<t->data<<",";BL1(t->l);BL1(t->r);}}ﻩvoidpreOrder2(ECS_data*t)//非递归前序遍历 { stack<ECS_data*>s;ﻩﻩECS_data*p=t;ﻩ while(p!=NULL||!s.empty())ﻩ { ﻩwhile(p!=NULL)ﻩﻩ { ﻩ ﻩcout<<p->data<<"";ﻩﻩ ﻩs.push(p);ﻩ ﻩ p=p->l;ﻩ }ﻩ if(!s.empty())ﻩ ﻩ{ﻩ p=s.top();ﻩﻩ s.pop();ﻩﻩﻩﻩp=p->r;ﻩﻩﻩ} ﻩ} }voidBL2(ECS_data*t)//递归中序遍历{if(NULL!=t){BL2(t->l);cout<<t->data<<",";BL2(t->r);}}ﻩvoidinOrder2(ECS_data*t)//非递归中序遍历 { ﻩstack<ECS_data*>s;ﻩ ECS_data*p=t;ﻩ while(p!=NULL||!s.empty()) { ﻩwhile(p!=NULL)ﻩﻩ {ﻩﻩﻩﻩs.push(p);ﻩ ﻩp=p->l; }ﻩ if(!s.empty()) { ﻩﻩ p=s.top();ﻩﻩﻩ cout<<p->data<<"";ﻩ ﻩs.pop(); ﻩﻩ p=p->r;ﻩ ﻩ} }ﻩ}voidBL3(ECS_data*t)//递归后序遍历{if(NULL!=t){BL3(t->l);BL3(t->r);cout<<t->data<<",";}} voidpostOrder3(ECS_data*t)//非递归后序遍历ﻩ{ﻩﻩstack<ECS_data*>s;ﻩ ECS_data*cur;//当前结点 ECS_data*pre=NULL;//前一次访问的结点 s.push(t);ﻩ while(!s.empty()) { ﻩcur=s.top();ﻩﻩ if((cur->l==NULL&&cur->r==NULL)|| ﻩﻩﻩ(pre!=NULL&&(pre==cur->l||pre==cur->r)))ﻩ ﻩ{ﻩﻩﻩ cout<<cur->data<<"";//假如当前结点没有孩子结点或者孩子节点都已被访问过ﻩﻩﻩﻩs.pop(); ﻩﻩﻩpre=cur;ﻩ }ﻩ ﻩelseﻩﻩﻩ{ﻩﻩ ﻩif(cur->r!=NULL)ﻩﻩ ﻩs.push(cur->r); ﻩif(cur->l!=NULL) ﻩﻩ s.push(cur->l);ﻩ ﻩ}ﻩ }ﻩ}ﻩintHeight(ECS_data*t)//求树高ﻩ{if(t==NULL)return0; ﻩelse {ﻩﻩ intm=Height(t->l);ﻩﻩﻩintn=Height(t->r);ﻩﻩﻩreturn(m>n)?(m+1):(n+1);ﻩ } }ﻩintCountLeaf(ECS_data*t)//求叶子总数ﻩ{ﻩﻩstaticintLeafNum=0;//叶子初始
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 临街店铺租赁合同样本
- 中保财产保险有限公司企业财产综合保险合同
- 三方股东股权分配合同模板
- 与软件开发人员签订的项目合同范例
- 专利授权与合作合同锦集2025
- 专业股民短线理财合同模板
- 二手房买卖合同解约范本大全
- 二手房交易的标准合同范本
- 临时用工劳动合同模板及安全规定
- 临时市场摊位租赁合同书
- 充电桩知识培训课件
- 2025年七年级下册道德与法治主要知识点
- 2025年交通运输部长江口航道管理局招聘4人历年高频重点提升(共500题)附带答案详解
- 老年髋部骨折患者围术期下肢深静脉血栓基础预防专家共识(2024版)解读
- 广东省广州市2025届高三上学期12月调研测试(零模)英语 含解析
- 偏瘫足内翻的治疗
- 药企质量主管竞聘
- 信息对抗与认知战研究-洞察分析
- 心脑血管疾病预防课件
- 手术室专科护士工作总结汇报
- 2025届高三听力技巧指导-预读、预测
评论
0/150
提交评论