二叉树之统计叶子数


数据结构实验之二叉树三:统计叶子数
Time Limit: 1000MS Memory limit: 65536K

题目描述

已知二叉树的一个按先序遍历输入的字符序列,如abc,,de,g,,f,,, (其中,表示空结点)。请建立二叉树并求二叉树的叶子结点个数。

输入

连续输入多组数据,每组数据输入一个长度小于50个字符的字符串。

输出

输出二叉树的叶子结点个数。

示例输入

abc,,de,g,,f,,,

示例输出

3
 
 
  1. #include <stdio.h>  
  2. #include <string.h>  
  3. #include <malloc.h>  
  4.   
  5. typedef struct node  
  6. {  
  7.     int data;  
  8.     struct node * left;  
  9.     struct node * right;  
  10. } tree;  
  11. char a[55],c;  
  12. int ans,l;  
  13. int sum;  
  14. tree * creat(tree * head)  
  15. {  
  16.     c=a[ans++];  
  17.   
  18.     if(c!=','&&ans<=l)  
  19.     {  
  20.         head=(tree*)malloc(sizeof(tree));  
  21.         head->data=c;  
  22.         head->left=creat(head->left);  
  23.         head->right=creat(head->right);  
  24.     }  
  25.     else head=NULL;  
  26.     return head;  
  27. }  
  28. void yezi(tree * head)  
  29. {  
  30.     if(head!=NULL)  
  31.     {  
  32.         if(head->left==NULL&&(head->right==NULL)) sum++;  
  33.         yezi(head->left); yezi(head->right);  
  34.     }  
  35. }  
  36. int main()  
  37. {  
  38.   
  39.     while(~scanf("%s",a))  
  40.     {  
  41.         ans=0; sum=0;  
  42.         l=strlen(a);  
  43.         tree * head;  
  44.         head=creat(head);  
  45.         yezi(head);  
  46.         printf("%d\n",sum);  
  47.     }  
  48.   
  49.     return 0;  
  50. }  
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值