全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法

本文实例讲述了C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法。分享给大家供大家参考,具体如下:

/*求二叉树叶子节点个数 -- 采用递归和非递归方法
经调试可运行源码及分析如下:
***/
#include <stdlib.h>
#include <iostream>
#include <stack>
using std::cout;
using std::cin;
using std::endl;
using std::stack;
/*二叉树结点定义*/
typedef struct BTreeNode
{
  char elem;
  struct BTreeNode *pleft;
  struct BTreeNode *pright;
}BTreeNode;
/*
求二叉树叶子节点数
叶子节点:即没有左右子树的结点
递归方式步骤:
如果给定节点proot为NULL,则是空树,叶子节点为0,返回0;
如果给定节点proot左右子树均为NULL,则是叶子节点,且叶子节点数为1,返回1;
如果给定节点proot左右子树不都为NULL,则不是叶子节点,以proot为根节点的子树叶子节点数=proot左子树叶子节点数+proot右子树叶子节点数。
/*递归实现求叶子节点个数*/
int get_leaf_number(BTreeNode *proot)
{
  if(proot == NULL)
    return 0;
  if(proot->pleft == NULL && proot->pright == NULL)
    return 1;
  return (get_leaf_number(proot->pleft) + get_leaf_number(proot->pright));
}
/*非递归:本例采用先序遍历计算
判断当前访问的节点是不是叶子节点,然后对叶子节点求和即可。
 **/
int preorder_get_leaf_number(BTreeNode* proot)
{
  if(proot == NULL)
    return 0;
  int num = 0;
  stack <BTreeNode*> st;
  while (proot != NULL || !st.empty())
  {
    while (proot != NULL)
    {
      cout << "节点:" << proot->elem << endl;
      st.push(proot);
      proot = proot->pleft;
    }
    if (!st.empty())
    {
      proot = st.top();
      st.pop();
      if(proot->pleft == NULL && proot->pright == NULL)
        num++;
      proot = proot -> pright;
    }
  }
  return num;
}
/*初始化二叉树根节点*/
BTreeNode* btree_init(BTreeNode* &bt)
{
  bt = NULL;
  return bt;
}
/*先序创建二叉树*/
void pre_crt_tree(BTreeNode* &bt)
{
  char ch;
  cin >> ch;
  if (ch == '#')
  {
    bt = NULL;
  }
  else
  {
    bt = new BTreeNode;
    bt->elem = ch;
    pre_crt_tree(bt->pleft);
    pre_crt_tree(bt->pright);
  }
}
int main()
{
  int tree_leaf_number = 0;
  BTreeNode *bt;
  btree_init(bt);//初始化根节点
  pre_crt_tree(bt);//创建二叉树
  tree_leaf_number = get_leaf_number(bt);//递归
  cout << "二叉树叶子节点个数为:" << tree_leaf_number << endl;
  cout << "非递归先序遍历过程如下:" << endl;
  tree_leaf_number = preorder_get_leaf_number(bt);//非递归
  cout << "二叉树叶子节点个数为:" << tree_leaf_number << endl;
  system("pause");
  return 0;
}
/*

运行结果:
a b c # # # d e # # f # #
---以上为输入---
---以下为输出---
二叉树叶子节点个数为:3
非递归遍历过程如下:
节点:a
节点:b
节点:c
节点:d
节点:e
节点:f
二叉树叶子节点个数为:3
请按任意键继续. . .

本例创建的二叉树形状:
    a
  b    d  
c     e  f
*/

希望本文所述对大家C++程序设计有所帮助。


# C++  # 递归  # 非递归  # 算法  # 二叉树  # 叶子节点  # 个数  # 计算  # C++实现二叉树非递归遍历算法详解  # C++二叉树的前序中序后序非递归实现方法详细讲解  # C++如何实现二叉树链表  # C++二叉树的创建及遍历详情  # C++链式二叉树深入分析  # C++简单又轻松建立链式二叉树流程  # C++超详细讲解树与二叉树  # C++实现二叉树的堂兄弟节点查询  # 子树  # 数为  # 遍历  # 则是  # 本例  # 均为  # 给大家  # 请按  # 都为  # 所述  # 程序设计  # 计算方法  # 上为  # 讲述了  # std  # cout  # stack  # iostream 


相关文章: 浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  设计网站制作公司有哪些,制作网页教程?  宝塔建站无法访问?如何排查配置与端口问题?  如何通过商城自助建站源码实现零基础高效建站?  教学网站制作软件,学习*后期制作的网站有哪些?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  网站微信制作软件,如何制作微信链接?  建站主机如何选?性能与价格怎样平衡?  定制建站是什么?如何实现个性化需求?  ,有什么在线背英语单词效率比较高的网站?  黑客入侵网站服务器的常见手法有哪些?  高防服务器:AI智能防御DDoS攻击与数据安全保障  制作表格网站有哪些,线上表格怎么弄?  香港服务器WordPress建站指南:SEO优化与高效部署策略  独立制作一个网站多少钱,建立网站需要花多少钱?  如何快速生成高效建站系统源代码?  广东专业制作网站有哪些,广东省能源集团有限公司官网?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  建站主机默认首页配置指南:核心功能与访问路径优化  家庭建站与云服务器建站,如何选择更优?  测试制作网站有哪些,测试性取向的权威测试或者网站?  公司网站设计制作厂家,怎么创建自己的一个网站?  如何通过虚拟机搭建网站?详细步骤解析  如何选择域名并搭建高效网站?  如何访问已购建站主机并解决登录问题?  建站之星如何实现网站加密操作?  英语简历制作免费网站推荐,如何将简历翻译成英文?  济南企业网站制作公司,济南社保单位网上缴费步骤?  建站之星安装模板失败:服务器环境不兼容?  建站主机选虚拟主机还是云服务器更好?  网站制作知乎推荐,想做自己的网站用什么工具比较好?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  建站之星后台管理:高效配置与模板优化提升用户体验  高端企业智能建站程序:SEO优化与响应式模板定制开发  金*站制作公司有哪些,金华教育集团官网?  如何在云主机上快速搭建多站点网站?  重庆市网站制作公司,重庆招聘网站哪个好?  高端建站如何打造兼具美学与转化的品牌官网?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  Bpmn 2.0的XML文件怎么画流程图  C#如何使用XPathNavigator高效查询XML  如何在景安云服务器上绑定域名并配置虚拟主机?  ,网页ppt怎么弄成自己的ppt?  如何在阿里云ECS服务器部署织梦CMS网站?  如何通过服务器快速搭建网站?完整步骤解析  音响网站制作视频教程,隆霸音响官方网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。