统计二叉树的结点个数

 我来答
徐幻巧0Fz
推荐于2017-11-25 · 超过22用户采纳过TA的回答
知道答主
回答量:74
采纳率:0%
帮助的人:69.2万
展开全部
void getNum(Node*p,int &n)
{
if(p!=NULL)
{
n=n+1;
getNum(p->Left,n);
getNum(p->Right,n);
}
else
{
return ;
}

}

其中 p为二叉树指针 , n返回的是 节点个数, n传参前需初始化为0;
匿名用户
2012-09-09
展开全部
#include <alloc.h>
#include <stdio.h>
typedef struct node
{ char data;
struct node *lchild,*rchild;
}JD;
void countleaf(JD *bt,int *count)
{ if(bt!=NULL)
{ if((bt->lchild==NULL)&&(bt->rchild==NULL))
{ (*count)++;
return;
}
countleaf(bt->lchild,count);
countleaf(bt->rchild,count);
}
}
JD *crt_bt_pre(JD *bt)
{ char ch;
printf("ch=");
scanf("%c",&ch);
getchar();
if(ch==' ') bt=NULL;
else
{ bt=(JD *)malloc(sizeof(JD));
bt->data=ch;
bt->lchild=crt_bt_pre(bt->lchild);
bt->rchild=crt_bt_pre(bt->rchild);
}
return(bt);
}
void main()
{ /* ABC00DE0G00F000 */
JD *head=NULL;
int count=0;
head=crt_bt_pre(head);
countleaf(head,&count);
printf("count of leaf node is %d\n",count);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
秒懂百科
2020-12-09 · TA获得超过5.9万个赞
知道大有可为答主
回答量:25.3万
采纳率:88%
帮助的人:1.3亿
展开全部

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友0521813
2018-05-28
知道答主
回答量:1
采纳率:0%
帮助的人:869
展开全部
void size(BONode *T)

if(T!=NULL)
return 1+size(T-lchild)+size(T-rchild);
else
return 0;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式