數据结构树和二叉树代码.docVIP

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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; //采用顺序队列,并假定

文档评论(0)

fv45ffsjjI + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档