- 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; //采用顺序队列,并假定不会
您可能关注的文档
最近下载
- 茶具知识介绍.docx
- 软件资格考试信息系统管理工程师(基础知识、应用技术)合卷(中级)试题与参考答案(2024年).docx VIP
- 体例格式9:工学一体化课程《windows服务器基础配置与局域网组建》任务3学习任务工作页.docx VIP
- 2025年保安员考试必刷题库500道带答案(满分必刷).docx VIP
- 超市劳务合同范本.docx VIP
- 6米路灯基础图.pdf VIP
- 专家咨询服务合同协议.docx VIP
- 体例格式9:工学一体化课程《windows服务器基础配置与局域网组建》任务5学习任务工作页.docx VIP
- 医疗技术档案管理制度.docx VIP
- 撤销裁判文书上网申请书.docx VIP
文档评论(0)