跟据先序和中序创建二叉树

本文介绍了如何根据先序遍历和中序遍历的顺序来构建二叉树。通过找到根节点及其在中序遍历中的位置,将剩余节点分为左子树和右子树,然后递归地对左右子树进行相同操作,最终构建出完整的二叉树结构。此外,还提供了用代码实现这一过程并进行先序、中序、后序遍历的示例。
摘要由CSDN通过智能技术生成

先序遍历顺序:根,左,右

中序遍历顺序:左,根,右

我们根据先序遍历找到根节点,然后根结点在中序遍历中的位置,可以将根结点外的结点看成两部分,左边结点全看成左孩子,右边结点全看成右孩子。两边结点分别在到先序中找根结点,依次类推。

假设先序序列为ABCDEFG   中序序列为CBDAEGF,用下图描述创建树的过程。

1.先序中第一个结点为A,中序中定位A,A的左边为左孩子,右边为右孩子。

 

2.先看左边这个圈,里面是CBD,先序中第一个为B,在中序中定位B,B的左边为C,右边为D

看右边这个圈,里面是EGF,先序中第一个结点为E,在中序中定位E,GF为右孩子。

3.现在可以看到只有EF中不止一个数据。类推上面的方法,先序中先是F,中序中定位F,G为F的左子树

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值