网站大量收购闲置独家精品文档,联系QQ:2885784924

叉树叶子结点个数计算.docVIP

  1. 1、本文档共4页,可阅读全部内容。
  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文档。上传文档
查看更多
叉树叶子结点个数计算

二叉树叶子结点个数计算 姓名:许严 班级:计122 学号:1213023050 问题描述 已知一棵二叉树,求该二叉树中叶子结点的个数。 基本要求 设计二叉树的二叉链表存储结构。 设计求叶子结点个数的递归算法。 输入:一棵二叉树。 输出:二叉树中叶子结点的个数。 实验提示 存储设计 二叉树采用二叉链表为存储结构。 typedef struct BiTNode{ TElemType data; Struct BiTNode *lchild,*rchild;//左右孩子指针 } BiTNode,*BiTree; 算法设计 求二叉树中叶子结点个数,即求二叉树的所有结点中左右字数均为空的结点个数之和。可以将此问题转化为遍历问题,在遍历中“访问一个结点”时判断该结点是不是叶子,若是则将计数器累加。算法如下: Void CountLeaf(BiNodeT*root,int count) //前序遍历根指针为root的二叉树以计算叶子树count,假定count 的初值为0 { if(root!=NULL){ If(root-lchild==NULLroot-rchild==NULL) Count++; CountLeaf(root-lchild,count); //累计在左子树上的叶子数 CountLeaf(root-rchild,count); //累计右子树上的叶子数 } } (3)程序如下 #includeiostream #includestring using namespace std; struct BiNode //二叉树的结点结构 { char data; BiNode *lchild, *rchild; }; class BiTree { public: BiTree( ); //构造函数,初始化一棵二叉树,其前序序列由键盘输入 ~BiTree(void); //析构函数,释放二叉链表中各结点的存储空间 BiNode* Getroot(); //获得指向根结点的指针 void PreOrder(BiNode *root); //前序遍历二叉树 void BiTree::yezi(BiNode *root,int n); private: BiNode *root; //指向根结点的头指针 BiNode *Creat( ); //有参构造函数调用 void Release(BiNode *root); //析构函数调用 }; BiTree::BiTree( ) { root = Creat( ); } BiTree::~BiTree(void) { Release(root); } BiNode* BiTree::Getroot( ) { return root; } void BiTree::PreOrder(BiNode *root) { if(root==NULL) return; else{ coutroot-data ; PreOrder(root-lchild); PreOrder(root-rchild); } } void BiTree::yezi(BiNode *root,int n) { if(root) { if(root-lchild==NULLroot-rchild==NULL) n++; yezi(root-lchild,n); yezi(root-rchild,n); } } BiNode* BiTree::Creat( ) { BiNode *root; char ch; cinch; if (ch==#) root = NULL; else{ root = new BiNode; //生成一个结 root-data=ch; root-lchild = Creat( ); //递归建立左子树 root-rchild = Creat( ); //递归建立右子树 } return root; } void BiTree::Release(BiNode *root) { if (root!= NULL){ Release(root-lchild); //释放左子树 Release(root-rchild); //释放右子树 delete root; } } void main() { cout请输入二叉树的结点数据:; BiTree

文档评论(0)

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

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

1亿VIP精品文档

相关文档