该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

void CreatBiTree(BiTree T)

{

char a;

scanf("%c",&a);

if(a=='@')

T=NULL;

else

{

T=(BiTree)malloc(sizeof(BiNode));

T->data=a;

CreatBiTree(T->lchild);

CreatBiTree(T->rchild);

}

}

虽能编译,但不能正确运行,冥思苦想n小时,未果

遂改其为

BiTree CreatBiTree()

{

char a;

BiTree T;

scanf("%c",&a);

if(a=='@')

T=NULL;

else

{

T=(BiTree)malloc(sizeof(BiNode));

T->data=a;

T->lchild=CreatBiTree();

T->rchild=CreatBiTree();

}

return T;

}

不再用传递参数,用返回值,正确编译运行,喜。

重审前程序,改为

void CreatBiTree(BiTree *T)

{

char a;

scanf("%c",&a);

if(a=='@')

*T=NULL;

else

{

*T=(BiTree)malloc(sizeof(BiNode));

(*T)->data=a;

CreatBiTree(&((*T)->lchild));

CreatBiTree(&((*T)->rchild));

}

}

正确编译运行,惑。

又冥思苦想n小时,终于悟出其中原由(好象多难似的,或者其实是我太愚钝)

原来还是对指针的理解不够深刻

最开始的程序传递的是Node型结构体的指针,于是在函数中会生成一个形参也指向这个结构体,但在函数中有一句T=(BiTree)malloc(sizeof(BiNode)); 改变了形参的指向,以后再对形参的任何操作不会在主函数中的T产生影响。

下面是两个完整的程序,分别用的两种建树方法

#include "stdlib.h"

#include "conio.h"

typedef struct node

{

char data;

struct node *lchild,*rchild;

}BiNode,*BiTree;

BiTree CreatBiTree()

{

char a;

BiTree T;

scanf("%c",&a);

if(a=='@')

T=NULL;

else

{

T=(BiTree)malloc(sizeof(BiNode));

T->data=a;

T->lchild=CreatBiTree();

T->rchild=CreatBiTree();

}

return T;

}

void PreOrderTraverse(BiTree T)

{

if(T)

{

printf("%c",T->data);

PreOrderTraverse(T->lchild);

PreOrderTraverse(T->rchild);

}

}

void InOrderTraverse(BiTree T)

{

if(T)

{

InOrderTraverse(T->lchild);

printf("%c",T->data);

InOrderTraverse(T->rchild);

}

}

void PostOrderTraverse(BiTree T)

{

if(T)

{

PostOrderTraverse(T->lchild);

PostOrderTraverse(T->rchild);

printf("%c",T->data);

}

}

main()

{

BiTree T;

clrscr();

T=CreatBiTree();

PreOrderTraverse(T);

printf("\n");

InOrderTraverse(T);

printf("\n");

PostOrderTraverse(T);

}

#include "stdlib.h"

#include "conio.h"

typedef struct node

{

char data;

struct node *lchild,*rchild;

}BiNode,*BiTree;

void CreatBiTree(BiTree *T)

{

char a;

scanf("%c",&a);

if(a=='@')

*T=NULL;

else

{

*T=(BiTree)malloc(sizeof(BiNode));

(*T)->data=a;

CreatBiTree(&((*T)->lchild));

CreatBiTree(&((*T)->rchild));

}

}

void PreOrderTraverse(BiTree T)

{

if(T)

{

printf("%c",T->data);

PreOrderTraverse(T->lchild);

PreOrderTraverse(T->rchild);

}

}

void InOrderTraverse(BiTree T)

{

if(T)

{

InOrderTraverse(T->lchild);

printf("%c",T->data);

InOrderTraverse(T->rchild);

}

}

void PostOrderTraverse(BiTree T)

{

if(T)

{

PostOrderTraverse(T->lchild);

PostOrderTraverse(T->rchild);

printf("%c",T->data);

}

}

main()

{

BiTree T;

clrscr();

CreatBiTree(&T);

PreOrderTraverse(T);

printf("\n");

InOrderTraverse(T);

printf("\n");

PostOrderTraverse(T);

}

更多数据结构实例http://hi.baidu.com/longzuo

c语言创建树,递归创建二叉树c语言实现+详细解释相关推荐

  1. C语言六叉树,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  2. c语言链表创建递归,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  3. c语言构造满二叉树,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  4. 如何创造char二叉树C语言,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  5. c语言递归建链表,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  6. 二叉树的递归遍历算法c语言 数据结构,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  7. 二叉树构造c语言实现,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  8. 二叉树学习笔记之利用前序遍历递归创建二叉树

    利用前序遍历创建二叉树 树的遍历 前序遍历(preorder traversal) 利用前序遍历创建二叉树 中序遍历访问所有结点 前序遍历访问所有结点 后序遍历访问所有结点 实例 树的遍历 树的遍历是 ...

  9. 先根序列创建二叉树c语言,用C语言创建二叉树并先序遍历.doc

    用C语言创建二叉树并先序遍历 用C语言创建二叉树并 #include "stdio.h" #include "stdlib.h" typedef struct ...

最新文章

  1. 软件体系结构的第3次实验(软件体系结构风格之应用 )
  2. 指纹图谱相似度评价软件_不同产地佛手指纹图谱及模式识别研究
  3. [BZOJ2818][P2568]Gcd[欧拉函数]
  4. 拖动内容,滚动条滚动,横向
  5. 解决库仑计初始化卡死问题
  6. 达梦数据库,查看表空间使用情况
  7. 原 Android studio下的DNK开发JNI详解流程
  8. NX/UG二次开发—CAM—快速查找程序参数名称
  9. 再次盈利的芒果超媒,下一步剑指电商
  10. 深度学习机器学习面试题(理论基础)
  11. SystemInit()时钟系统初始化函数解析
  12. 下取整函数的含义_向上取整⌈⌉和向下取整⌊⌋符号含义及应用
  13. python 选座位助手
  14. 英语知识系列:按发音规律重排的英语音标
  15. 简单(静态)工厂模式
  16. linux .gz文件 解压缩命令的简单使用
  17. 开源云盘搭建部署 施工中~
  18. linux监控某个端口流量抓包,tcpdump命令 – 监听网络流量
  19. python三个数从小到大排序
  20. 硬盘低级格式化需谨记

热门文章

  1. 对虚拟目录的操作(转)
  2. 一个完整的数据分析体系,该长啥样?
  3. Facebook泄露隐私算什么?国内一次外卖,竟让4万用户全“裸着”
  4. 巨坑!这公司的行为,挺适合清明节!
  5. 面试官:Redis中的缓冲区了解吗
  6. session、token、jwt、oauth2 傻傻分不清
  7. 趣图:老师讲算法 vs 油管三哥讲算法
  8. jeewx 微信管家 - 举办商业版本免费试用活动
  9. Java 中的日期与时间
  10. /etc/fstab文件出错,无法进入Linux系统