实验四、3求二叉树宽度

/*
  Description:对任意建立的一颗二叉树求其结点数和叶数
*/
#include<stdio.h>
#include<stdlib.h>
#define null 0
typedef struct btnode//二叉树结点
{
 char date;
 struct btnode *lc,*rc; 
}btnode;
btnode *t; //定义二叉树结点类型指针
btnode  *creattree()//创建二叉树并将而二叉树的跟结点指针返回
{
 //getchar();
 btnode *p;
 char ch;
 if((ch=getchar())=='#')//没有结点的用#表示
  p=null;
 else
 {
  p=(btnode*)malloc(sizeof(btnode));
  p->date=ch;
  p->lc=creattree();
  p->rc=creattree(); 
 }
 return(p);
}
int nodes(btnode *p)//统计p指向的树的结点总数
{
 int node=0;
 if(p==null)
  node=0;
 else
  node=1+nodes(p->lc)+nodes(p->rc);
 return (node);
}
int num=0;//叶子计数器
int leafs(btnode *p)//统计p指向的
{
 if(p)
 {
  leafs(p->lc);
  if(!(p->lc||p->rc))
   num++;
  leafs(p->rc); 
 }
 return (num); 
}
int main()
{
 btnode *s;
 int nodenum,leafnum;
 //s=null;
 printf("请输入结点:");
 s=creattree();
 nodenum=nodes(s);
 printf("%d/n",nodenum);
 leafnum=leafs(s);
 printf("%d/n",leafnum); 
 system("pause");  
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值