- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
數据结构树和二叉树代码
树和二叉树
一、实验目的:
参照给定的二叉树类的程序样例,验证给出的有关二叉树的常见算法,并实现有关的操作。
二、实验要求:
1、掌握二叉树、哈夫曼树和树的特点。掌握它们的常见算法。
2、提交实验报告,报告内容包括:目的、要求、算法描述、程序结构、主要变量说明、程序清单、调试情况、设计技巧、心得体会。
三、实验内容:
1.设计实现二叉树类,要求:
(1)编写一个程序,首先建立不带头结点的二叉链式存储结构的二叉树,然后分别输出按照前序遍历二叉树、中序遍历二叉树和后序遍历二叉树访问各结点的序列信息,最后再测试查找函数和撤销函数的正确性。
(2)实现二叉树层次遍历的非递归算法。
(3) 假设二叉树采用链式存储结构进行存储,编写一个算法,输出一个二叉树的所有叶子结点,并统计叶子结点个数。
(4)编写求二叉树高度的函数
(5)编写一主函数来验证算法实现。
2. 设计实现二叉线索链表类,要求:
(1)编写一个程序,首先建立中序线索链表的二叉树,然后实现中序线索链表的遍历算法。
(2)编写一主函数来验证算法实现。
*3. 编写创建哈夫曼树和生成哈夫曼编码的算法。
*4.假设二叉树采用链式存储结构进行存储,试设计一个算法,输出从每个叶子结点到根结点的路径。
*5.假设二叉树采用链式存储结构进行存储,试设计一个算法,求二叉树的宽度(即具有结点数最多的层次上结点总数)
四、程序样例
#includeiostream
#includequeue
using namespace std;
template class T
struct BiNode{
T data;
BiNodeT *lchild, *rchild;
};
int max(int a,int b){
return a b ? a : b; }
template class T
class BiTree{
public:
BiTree( ); //构造函数,初始化一棵空的二叉树
~BiTree()//二叉树的析构函数算法BiTree
{ Release(root); }
void InOrder() { InOrder(root);} //中序遍历二叉树
void PreOrder(){ PreOrder(root);}
void PostOrder(){PostOrder(root);} //后序遍历二叉树
void LeverOrder(){LeverOrder(root);} //层序遍历二叉树
void Count(){Count(root);}
void PreOrdercnt(){PreOrdercnt(root);}
int Depth(){int www = Depth(root); return www;}
private:
BiNodeT *root; //指向根结点的头指针
void Creat(BiNodeT *root);
void PreOrder(BiNodeT *root); //前序遍历二叉树
void InOrder(BiNodeT *root);
void PostOrder(BiNodeT *root);
void LeverOrder(BiNodeT *root); //层序遍历二叉树
void Release(BiNodeT *root); //析构函数调用
void Count(BiNodeT *root) ;/////求二叉树的结点个数
void PreOrdercnt(BiNodeT *root);///设计算法按前序次序打印二叉树中的叶子结点;
int Depth(BiNodeT *root);//深度;
};
template class T
BiTreeT::BiTree(){
Creat(root);}
template class T
void BiTreeT ::Creat(BiNodeT *root) {
char ch;
cinch;
if (ch==#) root=NULL; //建立一棵空树
else {
root=new BiNodeT; //生成一个结点
root-data=ch;
Creat(root-lchild); //递归建立左子树
Creat(root-rchild); //递归建立右子树
}
}
template class T
void BiTreeT::LeverOrder(BiNodeT *root){
BiNodeT * Q[100];
int front = 0, rear = 0; //采用顺序队列,并假定
您可能关注的文档
- 教育信息化建設工作制度及岗位职责.doc
- 教育創新的起点之激发学生的英语学习兴趣.doc
- 教育反思作業.doc
- 教育反思與案例作业.doc
- 教育中的第十名現象.doc
- 教育和管理過程中的权利义务分析.doc
- 教育問题案例研究.doc
- 教育培訓制度汇编.doc
- 教育培訓行业HR岗位胜任力.doc
- 教育子女的根本規律-董进宇博士.doc
- 轻量化材料在新能源汽车电池包中的应用与产业链整合发展报告.docx
- 制造业头部企业转型升级增长模式研究报告(2025年).docx
- 电子竞技俱乐部电竞赛事赞助策略与品牌合作模式研究报告.docx
- 智能养老社区养老机构服务模式创新与市场拓展报告.docx
- 2025年供应链金融创新与中小企业融资政策优化案例分析报告.docx
- 高校产学研一体化协同发展模式在绿色环保产业中的应用与成效评估报告.docx
- 水泥行业节能减排技术创新与区域市场竞争格局研究报告.docx
- 社区养老服务平台2025年建设与智慧养老市场分析.docx
- 生物制药行业生物制药产品注册与审批流程分析报告.docx
- 2025年工业废气净化处理技术环保设备运行成本分析报告.docx
最近下载
- 知识产权法智慧树知到期末考试答案章节答案2024年同济大学.docx VIP
- 临床医学教学模式创新与课堂互动设计.pptx
- 生猪屠宰兽医卫生检验人员理论考试题库资料及答案.pdf VIP
- 天津市静海区2024-2025学年高一下学期6月学生学业能力调研试题 地理试卷含答案.docx VIP
- 有限空间安全作业技术交底.docx VIP
- 消防设施操作员(中级监控方向)理论知识考试题库(含答案解析).pdf VIP
- 小学校园心理危机干预培训.pptx VIP
- 《内部控制与风险管理(第3版)》思考题和案例分析答案6-10章.docx VIP
- 军职在线-雷达原理-2023年春期末考试答案.docx VIP
- 佛山第六次人口普数据分析.doc VIP
文档评论(0)