数据结构——关于给定先序序列和中序序列建立一棵二叉树

如给定一棵二叉树的先序序列和中序序列如下:
先序序列:ABDEHIJKCFG
中序序列:DBHEJIKAFEG
如何建立唯一确定的二叉树呢?

思路和方法:

通过先序序列找到根结点和末尾元素,因为先序和中序最后遍历的都是右子树,所以末尾相同元素即为根节点的右子树,不断对比,每找到一棵子树的根结点就用斜线将其左右与其他元素断开分成一颗颗子树。

步骤如下:

先序序列:A B D E H I J K C F G
中序序列:D B H E J I K A F C G

  1. 在先序中找到根结点A,对应在中序中将A的左右断开
    先序:A B D E H I J K C F G
    中序:D B H E J I K A F C G
    在这里插入图片描述
  2. 对比先序和中序的末尾,找到相同的字母即为根节点的右子树
    这里C F G即是构成根结点右子树
    在这里插入图片描述
    在这里插入图片描述
  3. B为A的子树,也即A子树的根结点,B两边断开后发现D为左子树,E为右子树
    中序中H比E先遍历,说明H为E的左子树,E为子树结点
  4. H I 为E的左右孩子,根据中序遍历知道,J在I前面遍历,说明J为I的左孩子,I为根结点
    在这里插入图片描述

最终结果:

在这里插入图片描述

先序序列中序序列可以用来唯一确定一棵二叉树,这是因为在二叉搜索树中先序遍历的第一个元素是根节点,中序遍历时根节点总是在左子树遍历结束后、右子树开始之前。 以下是使用递归法将这两个序列转换为二叉树的过程: 1. **先序遍历** (Preorder):首先访问根节点,然后递归地对左子树进行先序遍历,最后对右子树进行先序遍历。 2. **中序遍历** (Inorder):对于左子树,我们需要先做中序遍历,接着访问根节点,最后遍历右子树。 给定两个序列: - 先序遍历序列:`[root, left, right]` - 中序遍历序列:`[left, root, right]` 我们可以按照以下步骤构建二叉树: - **找到根节点**:先序序列的第一个元素是根节点。 - **找到根节点在中序序列的位置**:由于先序是左-根-右,所以可以在中序序列中找到根节点的前驱元素作为左孩子的结束位置。 - **递归创建左右子树**:分别在中序序列的左半部分和剩余部分中,用同样的方法找到左子树和右子树的先序中序序列。 递归函数的伪代码可能像这样: ```python def build_tree(preorder, inorder): if not preorder or not inorder: return None # 根据先序遍历找根节点 root_value = preorder[0] # 找到根节点在中序中的索引 index = inorder.index(root_value) # 递归创建左子树和右子树 root = TreeNode(root_value) root.left = build_tree(preorder[1:index], inorder[:index]) root.right = build_tree(preorder[index + 1:], inorder[index + 1:]) return root ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值