c语言二叉树,c语言二叉树代码

dfnjsfkhak 43 0

大家好,今天小编关注到一个比较意思的话题,就是关于c语言二叉树的问题,于是小编就整理了3个相关介绍c语言二叉树的解答,让我们一起看看吧。

  1. 创建二叉树是怎么输入?
  2. 已知一棵二叉树的前序序列和中序序列分别是ABCDEFGHIJ和BAEDCHGIFJ,构造二叉树,并写出其后序序列?
  3. 二叉树前序遍历abdgcef中序遍历dgbaechf后序遍历怎么求?

创建二叉树是怎么输入

void CreateTree(BTree *T){char c;c=getchar();getchar();//lchild);(*T)->data=c;CreateTree(&(*T)->rchild);}}输入为(只是一个例子)先序输入二叉树:ab#C###先序遍历:a b C先序遍历(非递归):a b C中序遍历:b C a中序遍历(非递归):b C a后序遍历:C b a后序遍历(非递归):C b a层次遍历(链式):a b C层次遍历(顺序):a b CPress any key to continue

已知一棵二叉树的前序序列和中序序列分别是ABCDEFGHIJ和BAEDCHGIFJ,构造二叉树,并写出其后序序列?

这是递归算法

c语言二叉树,c语言二叉树代码-第1张图片-芜湖力博教育咨询公司
图片来源网络,侵删)

前序第一个必定是根,根就是A,

从中序中就能分出左、右子树了:B和EDCHGIFJ,这是中序

就可据此从前序中分出左、右子树了:B和CDEFGHIJ,这是前序了。

c语言二叉树,c语言二叉树代码-第2张图片-芜湖力博教育咨询公司
(图片来源网络,侵删)

这样一个问题变成了两个同样的小问题了,递归下去不就解决了。

多动动脑筋就出来了

二叉树前序遍历abdgcef中序遍历dgbaechf后序遍历怎么求?

其实很简单 跟着我的思路来。

c语言二叉树,c语言二叉树代码-第3张图片-芜湖力博教育咨询公司
(图片来源网络,侵删)
。。画出来了这个树,就很简单了对吧 前序遍历是先根。我们看abdgcef,第一个是a,说明整个树的根是a。中序遍历中根,我们看dgbaechf。既然a是整个树的根,那么a左边的dgb就是左子树,a右边echf就是右子树。再看前序遍历:a是根,那么接下来就应该是左子树了。我们把左子树分离出来看 既然中序遍历已经知道是dgb了,那么前序遍历就是a后面的bdg。已知左子树的前序遍历是bdg,中序遍历是dgb,求左子树的形状。看,这不又变成刚才的问题了吗?只不过是规模减小了。显然,根是d,d的左儿子是b,d的右儿子是g。以此类推,就能画出整个Tree了。很简单吧!多用手模拟一下,多做两三题,很快就能掌握了。如果还不懂还可以Q我:328880142

到此,以上就是小编对于c语言二叉树的问题就介绍到这了,希望介绍关于c语言二叉树的3点解答对大家有用

标签: 遍历 子树 递归