24小时热门版块排行榜    

查看: 1353  |  回复: 8

邦桀南瑜

银虫 (小有名气)

[交流] 二叉树的动态创建 已有4人参与

#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>

typedef struct node
{
char data;
struct node *lchild, *rchild;
}bnode,*btree;

void createbtree(btree &t,int &n)
{
char x;
btree q;
n=n+1;
printf("\nInput  %d  DATA:",n);
x=getchar();
if(x!='\n')getchar();
if (x=='\n')return  ;

q=(btree)malloc(sizeof(bnode));
q->data=x;
q->lchild=NULL;
q->rchild=NULL;
t=q;
printf(" This Address is: %o, Data is:  %c,\n  Left Pointer is: %o,  Right Pointer is:  %o",q,q->data,q->lchild,q->rchild);
createbtree(q->lchild,n);
createbtree(q->rchild,n);
return  ;
}

void visit(btree e)
{
printf("  Address: %o,  Data:  %c,  Left Pointer: %o,  Right Pointer:  %o\n",e,e->data,e->lchild,e->rchild);
}

void pretraverse(btree t)
{
if(t)
{
  visit(t);
  pretraverse(t->lchild);
  pretraverse(t->rchild);
}
else
return ;
}

void countleaf(btree t,int &c)
{
        if(t!=NULL)
  {
          if (t->lchild==NULL && t->rchild==NULL)
          {c=c+1;
          }
   countleaf(t->lchild,c);
   countleaf(t->rchild,c);
  }
}

int treehigh(btree t)
{
  int lh,rh,h;
if(t==NULL)
  h=0;
else
{
  lh=treehigh(t->lchild);
  rh=treehigh(t->rchild);
  h=(lh>rh? lh:rh)+1;
}
return h;
}
int main()
{
btree t; int count=0,n=0;
printf("\n Please input TREE Data:\n";
createbtree(t,n);
printf("\n  This is TREE Struct: \n";
pretraverse(t);
countleaf(t,count);
printf("\n This TREE has %d leaves,  High of The TREE is: %d\n",count,treehigh(t));
return 0;
}
Sample Text有没有谁能看出输入语句是如何结束的?
动态创建二叉树的思路是什么?

[ Last edited by 邦桀南瑜 on 2013-11-15 at 20:08 ]
回复此楼

» 猜你喜欢

%d%ld%f%lf%x%X%#x%#X%c%o
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

想念异地的你

金虫 (小有名气)

强占1楼

[ 发自手机版 http://muchong.com/3g ]
路在脚下
2楼2013-11-15 23:44:04
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yongcailiu

金虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
createbtree()函数用的是递归方法实现的,其中输入语句结束条件是 if (x=='\n') return  ;
3楼2013-11-16 07:53:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

programfanny

铁杆木虫 (正式写手)



小木虫: 金币+0.5, 给个红包,谢谢回帖
输入语句结束条件是 if (x=='\n') return  ;
直接回车时结束
4楼2013-11-16 16:40:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

邦桀南瑜

银虫 (小有名气)

引用回帖:
3楼: Originally posted by yongcailiu at 2013-11-16 07:53:14
createbtree()函数用的是递归方法实现的,其中输入语句结束条件是 if (x=='\n') return  ;

不是‘、n’结束,按下回车键才会结束。
%d%ld%f%lf%x%X%#x%#X%c%o
5楼2013-11-17 18:40:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

邦桀南瑜

银虫 (小有名气)

引用回帖:
4楼: Originally posted by programfanny at 2013-11-16 16:40:56
输入语句结束条件是 if (x=='\n') return  ;
直接回车时结束

一个回车无法实现结束,必须多个回车键。
%d%ld%f%lf%x%X%#x%#X%c%o
6楼2013-11-17 18:41:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chentianyu1

木虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
引用回帖:
5楼: Originally posted by 邦桀南瑜 at 2013-11-17 18:40:37
不是‘、n’结束,按下回车键才会结束。...

\n就是回车......
7楼2013-11-18 20:16:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

邦桀南瑜

银虫 (小有名气)

引用回帖:
7楼: Originally posted by chentianyu1 at 2013-11-18 20:16:53
\n就是回车.........

回车不是\r吗?怎么成了\n呢?
%d%ld%f%lf%x%X%#x%#X%c%o
8楼2013-11-20 22:28:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chentianyu1

木虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
引用回帖:
8楼: Originally posted by 邦桀南瑜 at 2013-11-20 22:28:55
回车不是\r吗?怎么成了\n呢?...

学计算机的同学应该首先学会使用搜索引擎.......
9楼2013-11-21 00:21:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 邦桀南瑜 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 0703化学调剂 ,六级已过,有科研经历 +7 曦熙兮 2026-03-15 7/350 2026-03-16 16:34 by houyaoxu
[基金申请] 国自科面上基金字体 +5 iwuli 2026-03-12 6/300 2026-03-16 13:13 by Kamiu_MK
[考研] 326求调剂 +4 上岸的小葡 2026-03-15 5/250 2026-03-16 08:39 by Linda Hu
[考研] 材料与化工 323 英一+数二+物化,一志愿:哈工大 本人本科双一流 +4 自由的_飞翔 2026-03-13 5/250 2026-03-14 19:39 by hmn_wj
[考研] 265求调剂 +4 威化饼07 2026-03-12 4/200 2026-03-14 17:23 by userper
[考研] 265求调剂 +9 小木虫085600 2026-03-09 12/600 2026-03-14 01:11 by JourneyLucky
[考研] 求调剂,一志愿江南大学环境工程085701 +3 Djdjj12 2026-03-10 4/200 2026-03-14 00:31 by JourneyLucky
[考研] 材料工程,326分,求调剂 +6 KRSLSR 2026-03-10 6/300 2026-03-13 23:47 by JourneyLucky
[考研] 材料与化工304求B区调剂 +5 邱gl 2026-03-11 6/300 2026-03-13 22:37 by JourneyLucky
[考研] 336求调剂 +6 Iuruoh 2026-03-11 6/300 2026-03-13 22:06 by JourneyLucky
[考研] 0856材料与化工301求调剂 +5 奕束光 2026-03-13 5/250 2026-03-13 22:00 by 星空星月
[考研] 285化工学硕求调剂(081700) +6 柴郡猫_ 2026-03-12 6/300 2026-03-13 20:46 by hmn_wj
[考研] 材料与化工085600调剂求老师收留 +9 jiaanl 2026-03-11 9/450 2026-03-13 20:22 by JourneyLucky
[考研] 【考研调剂求收留】 +3 Ceciilia 2026-03-11 3/150 2026-03-13 20:18 by JourneyLucky
[考研] 0703化学求调剂 +7 绿豆芹菜汤 2026-03-12 7/350 2026-03-13 17:25 by njzyff
[考研] 302求调剂 +6 负心者当诛 2026-03-11 6/300 2026-03-13 16:11 by JourneyLucky
[考研] 工科调剂 +4 Jiang191123! 2026-03-11 4/200 2026-03-13 15:15 by Miko19
[考研] 268求调剂 +4 好运连绵不绝 2026-03-12 4/200 2026-03-13 10:45 by hyswxzs
[考研] 材料专硕274一志愿陕西师范大学求调剂 +4 薛云鹏 2026-03-13 4/200 2026-03-13 10:40 by 学员8dgXkO
信息提示
请填处理意见