网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

编程语言之如何统计二叉树中叶子节点数量和计算树高

这篇文章主要为大家展示了“编程语言之如何统计二叉树中叶子节点数量和计算树高”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“编程语言之如何统计二叉树中叶子节点数量和计算树高”这篇文章吧。

成都创新互联公司企业建站,十年网站建设经验,专注于网站建设技术,精于网页设计,有多年建站和网站代运营经验,设计师为客户打造网络企业风格,提供周到的建站售前咨询和贴心的售后服务。对于成都网站建设、网站制作中不同领域进行深入了解和探索,创新互联在网站建设中充分了解客户行业的需求,以灵动的思维在网页中充分展现,通过对客户行业精准市场调研,为客户提供的解决方案。

1、已知二叉树以二叉链表进行存储,其中结点的数据域为data,编写算法,统计二叉树中叶子结点值等于x的结点数目。

typedef struct BTNode 
{ 
  int data; 
  struct BTNode *lchild ; //左孩子指针 
  struct BTNode *rchild;  // 右孩子指针 
} BTNode;//二叉链表的结构
int num = 0;//用于统计有多少个结点的值与x的值相等
int CountLeaf (BTNode *P, int& num, int x)
{
  if ( P ) 
  {
    if (( P->lchild == NULL)&& ( P->rchild == NULL) && ( P->data == x))
      num++;   // 对叶子结点计数
    if (( !P->lchild) && ( !P->rchild))
    {
      CountLeaf( P->lchild, num, x); 
      CountLeaf( P->rchild, num, x);
    } 
  } 
  return num;
}

2、已知一棵二叉链表方式存储的二叉树,编写算法计算二叉树的高度。

typedef struct BTNode 
{ 
  int data; 
  struct BTNode *lchild ; //左孩子指针 
  struct BTNode *rchild;  // 右孩子指针 
} BTNode;//二叉链表的结构
int TreeHeight(BTNode *root)
{
  if (root == NULL)
  {
    return 1;  //如果是只有根节点,高度记为1
  }
  else
  {  //否则递归计算其左右孩子的高度然后在加上根节点的层数1
    return 1+max(TreeHeight(root->lchild),TreeHeight(root->rchild));
  }
}

以上是“编程语言之如何统计二叉树中叶子节点数量和计算树高”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


分享题目:编程语言之如何统计二叉树中叶子节点数量和计算树高
本文网址:http://bjjierui.cn/article/ppghio.html

其他资讯