| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1133 人关注过本帖
标题:请教各位老师一个问题:有关先序、中序确定二叉树的算法
只看楼主 加入收藏
cillin
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2005-3-10
收藏
 问题点数:0 回复次数:4 
请教各位老师一个问题:有关先序、中序确定二叉树的算法

在网上一个论坛搜到的,原出处:http://60.28.222.210/dispbbs.asp?BoardID=60&id=25234&replyID=25234&star=1&skin=0

我感觉这个算法在建立右子树根的判断上是有点问题的:当前已建立的根结点(visited[p])在中序序列中的后继元素(visited[p+1])就是该根结点的右子树根吗?中序序列中的某点的的后继元素应该是该结点的右子树的最左孩子才对啊?
刚学数据结构不久,请各位前辈指教。愚钝之处还请包涵,谢谢。

#define FALSE 0
#define TRUE 1
typedef int Status;

Status createTree(BiTree &T, BiTNode pre[], BiTNode order[]){
// 已知先序序列pre和中序序列order,构建一个二叉树T的非递归实现。
// 其中涉及到的数据结构请参看清华大学《数据结构》(C语言版)

InitStack(Stack); //初始化栈
for (i = 0; i < order.length; i ++) visited[ i ] = FALSE;
// 初始化visited,visited用于标记order
// 中的元素是否已经被访问过
T = (BiTree *) malloc (sizeof(BiTree));
T.data = pre[0]; T -> lchild = NULL; T -> rchild = NULL;
// 生成根节点,先序pre中的第一个元素肯定是树根,
// 左右孩子初始化为NULL。
p = LocateElem(order, pre[0].data); // 在order中找到根节点所在的位置
visited[ p ] = TRUE; // 标识order中的根元素已被访问过
cur = T; // cur表示当前构建的节点

for (i = 1; i < pre.length; ) {

if (p > 0 && !visited[p - 1]) {
// 在order中pre[ i ]的左边有元素并且未被访问过,说明有左子树存在,
// 生成左子树
cur->lchild = (BiTNode *) malloc (sizeof(BiTNode));
cur->lchild.data = pre[ i ];
// 将当前pre中的元素赋给lchild后指向下一个元素
cur->lchild->lchild = NULL; cur->rchild->rchild= NULL;
p = LocateElem(order, pre[ i ++].data); // 定位pre[ i ]的位置
visited[ p ] = TRUE;
Push(Stack, cur); // 当前节点进栈
cur = cur->lchild; // 当前节点指向左孩子
}
else if (p < order.length && !visited[p + 1]) {
// 生成右子树
cur->lchild = NULL; // 没有左孩子
cur->rchild = (BiTNode *) malloc (sizeof(BiTNode));
cur->rchild.data = pre[ i ];
cur->rchild.lchild = NULL; cur->rchlid.rchild = NULL;
p = LocateElem(order, pre[ i ++].data); // 定位pre[ i ]的位置
visited[ p ] = TRUE;
cur = cur->rchild;
}
else {
Pop(Stack, cur); // 左右都没有子树即是叶子,则退栈
p = LocateElem(order, cur.data); // 重新定位p的位置
}
}
}

思路捋顺了,谢谢回帖的前辈们。
(智商不太高偶尔会犯傻钻S胡同,还请见谅:)

[此贴子已经被作者于2007-8-26 16:48:37编辑过]

搜索更多相关主题的帖子: 中序 二叉树 算法 结点 
2007-08-26 09:51
aipb2008
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2007-6-1
收藏
得分:0 
代码没看,看你问的你似乎对前中后序有点不清楚。

a
b c
d e f g

pre :abdecfg
in :dbeafcg
post :debfgca

[glow=255,yellow,4]Fight to win or die...[/glow]
2007-08-26 14:04
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
看我的二叉树帖子吧,有递归的程序,参考一下。

倚天照海花无数,流水高山心自知。
2007-08-26 15:15
cillin
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2005-3-10
收藏
得分:0 
以下是引用aipb2008在2007-8-26 14:04:09的发言:
代码没看,看你问的你似乎对前中后序有点不清楚。

a
b c
d e f g

pre :abdecfg
in :dbeafcg
post :debfgca

谢谢,问题解决。

[此贴子已经被作者于2007-8-26 16:46:17编辑过]


2007-08-26 15:17
cillin
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2005-3-10
收藏
得分:0 
以下是引用nuciewth在2007-8-26 15:15:13的发言:
看我的二叉树帖子吧,有递归的程序,参考一下。

找到了,谢谢。


2007-08-26 15:20
快速回复:请教各位老师一个问题:有关先序、中序确定二叉树的算法
数据加载中...
 
   



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

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