| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 729 人关注过本帖
标题:树的叶子节点和非叶子结点为什么求不出来啊?
取消只看楼主 加入收藏
cwl168
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2012-12-14
结帖率:8.33%
收藏
已结贴  问题点数:10 回复次数:0 
树的叶子节点和非叶子结点为什么求不出来啊?
#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
快速回复:树的叶子节点和非叶子结点为什么求不出来啊?
数据加载中...
 
   



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

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