| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 729 人关注过本帖
标题:树的叶子节点和非叶子结点为什么求不出来啊?
只看楼主 加入收藏
cwl168
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2012-12-14
结帖率:8.33%
收藏
已结贴  问题点数:10 回复次数:4 
树的叶子节点和非叶子结点为什么求不出来啊?
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
typedef struct Node
{
      int data;
      struct Node *lchild;
      struct Node *rchild;
}BiTree,*BiTNode;

BiTNode InitDSTable()
{
    char ch;
    BiTNode t;
    ch=getchar();
    if(ch=='#')
    {  
         return NULL;
    }
    else
    {
      t=(BiTNode)malloc(sizeof(BiTree));  
      t->data=ch;
      t->lchild=InitDSTable();
      t->rchild=InitDSTable();
    }
    return t;
}
//递归中序遍历
void InOrderTravese(BiTNode T)
{
    if(T)
    {
        InOrderTravese(T->lchild);
        printf("%c",T->data);
        InOrderTravese(T->rchild);
    }
}
//求叶子的结点数和非叶子结点数
int  n1=0,n2=0;//n1非叶子结点,n2为叶子结点数
void Count(BiTNode T)
{
     if(T->lchild==NULL && T->rchild==NULL)
              n1++;
          else
              n2++;
     Count(T->lchild);
     Count(T->rchild);

}
int main()
{     
      printf("请创建二叉树(#表示指针为空):\n");
      BiTNode T=InitDSTable();
      printf("中序遍历的结果为:\n");
      InOrderTravese(T);
      Count(T);
      printf("叶子结点数和非叶子结点的个数为:%d,%d",n1,n2);
     
      return 0;

}
搜索更多相关主题的帖子: void include return 叶子 
2013-01-08 20:48
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:3 
void Count(BiTNode T)
 {
      if(T == NULL) {
            return;
      }

      if(T->lchild==NULL && T->rchild==NULL)
          n1++; // 这个为叶子
      else
          n2++; // 非叶子 你的注释有误吧

      Count(T->lchild);
      Count(T->rchild);
 
}

[ 本帖最后由 yuccn 于 2013-1-8 20:58 编辑 ]

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-01-08 20:54
不玩虚的
Rank: 9Rank: 9Rank: 9
来 自:四川
等 级:贵宾
威 望:10
帖 子:331
专家分:1301
注 册:2012-12-9
收藏
得分:3 
同上,注释有问题!

同学习......同进步....你帮我......我帮你.....上善若水.....
2013-01-09 09:27
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:3 
表示刚学数据结构,帮不上忙

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-09 12:36
xinglinzhang
Rank: 1
等 级:新手上路
帖 子:5
专家分:2
注 册:2013-1-14
收藏
得分:3 
大神,我运行后,程序没问题。但运行到 BiTNode T=InitDSTable();这步后有问题了。麻烦把运行过程发下,谢谢!!
2013-01-14 20:24
快速回复:树的叶子节点和非叶子结点为什么求不出来啊?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024387 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved