| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1364 人关注过本帖
标题:[原创]数据结构(严蔚敏C语言版)---二叉树的先序创建与遍历
只看楼主 加入收藏
Lenying
Rank: 1
等 级:禁止访问
帖 子:16
专家分:5
注 册:2006-11-25
收藏
 问题点数:0 回复次数:1 
[原创]数据结构(严蔚敏C语言版)---二叉树的先序创建与遍历
*/ --------------------------------------------------------------------------------------
*/ 出自: 编程中国 http://www.bc-cn.net
*/ 作者: Lenying
*/ 时间: 2007-10-24 编程论坛首发
*/ 声明: 尊重作者劳动,转载请保留本段文字
*/ --------------------------------------------------------------------------------------


#define OK 1
#define NULL 0

typedef int Status;
typedef struct BitNode
{
char data;
struct BitNode *lchild,*rchild;
}BitNode,*BitTree;

main()
{
Status CreateBitTree(BitTree *T);
Status PreOrderTraverse(BitTree T);
BitTree tree;
CreateBitTree(&tree);
printf("\n");
PreOrderTraverse(tree);
getch();
return OK;
}

Status CreateBitTree(BitTree *T)
{
char ch;
scanf("%c",&ch);
if(ch==' ') *T=0;
else
{
*T=(BitNode*)malloc(sizeof(BitNode));
(*T)->data=ch;
CreateBitTree(&((*T)->lchild));
CreateBitTree(&((*T)->rchild));

}
return OK;
}

Status PreOrderTraverse(BitTree T)
{
if(T)
{
printf("%c",T->data);
PreOrderTraverse(T->lchild);
PreOrderTraverse(T->rchild);
}
else
return OK;
}
说明:1、以上程序经测试通过。
2、以上程序是数据结构(严蔚敏C语言版)的第6章129页算法6.1和第131页算法6.4的具体实现。
3、在BitTree *T中,T是二级指针,即指向指针的指针。
4、可以以书中127页图6.8(b)为例:输入 ABC--DE-G--F--- 其中“-”代表空格。图如下:
A
/
B
/ \
C D
/ \
E F
\
G

搜索更多相关主题的帖子: 严蔚敏 二叉树 遍历 数据结构 C语言 
2007-10-24 18:42
ondy
Rank: 1
等 级:新手上路
威 望:1
帖 子:88
专家分:0
注 册:2007-9-4
收藏
得分:0 
二叉树的遍历算法是基础哦,
顶一下

2007-10-24 19:42
快速回复:[原创]数据结构(严蔚敏C语言版)---二叉树的先序创建与遍历
数据加载中...
 
   



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

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