一棵树的后序遍历和这棵树对应的二叉树的中序遍历相同 以及 高效的二叉树~

一棵树的后序遍历和这棵树对应的二叉树的()相同。
A.先序遍历 B.中序遍历 C.后序遍历 D.层次遍历

嗯 就这么道题

拆分下题目就是
一棵树的后序遍历 == 这棵树拆成二叉树的中序遍历
下面来解题

1.解题

来解题
这题
其实用试的是很快的~
还是用这个例子

【1】普通树的后序遍历

在这里插入图片描述

后序遍历 左右中(左后 右后 根)—— 翻译得详细些就是——

最开始 遍历到(还有左子树的)最深处的节点

【1】先访问该节点的左子树

2

【2】然后访问其余子树(以同样规则访问其余子树—先左后其他)

56 3 - 4

【3】最后访问根

1

得到结果 2 5634 1

【2】二叉树的中序遍历

  • 26
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 已知一棵二叉树列和后列,可以通过递归的方式求出这棵的前列。具体步骤如下: 1. 后的最后一个节点一定是根节点,将它作为根节点。 2. 在找到根节点的位置,根节点左侧的所有节点都属于左子,右侧的所有节点都属于右子。 3. 根据左子和右子的节点数量,在后确定左子和右子的边界。 4. 对左子和右子分别递归求解,得到左子和右子的前列。 5. 将根节点加入前列的最前面,得到最终的前列。 需要注意的是,如果列和后存在重复的节点,需要根据前列的定义确定节点的先后顺。通常情况下,可以将的重复节点放在左子,这样可以确保得到正确的前列。 综上所述,已知一棵二叉树列和后列,可以通过递归的方式求解这棵的前列。 ### 回答2: 根据二叉树的特点,前列的第一个元素为根节点,后列的最后一个元素也为根节点,而列可以将分为左子和右子,因此可以利用递归的思想,通过列和后列来求解。 在找到根节点的位置,将列分为左子和右子。在后找到根节点后,根节点左边的列就是左子的后列,右边的列就是右子的后列。 利用上述方法,可以递归的求出左子和右子的前列,最后将根节点和左子、右子的前列拼接起来即为所求的答案。 以示例为例,假设列为{D,B,E,A,F,C},后列为{D,E,B,F,C,A}: 1. 根据后列,找到根节点为A; 2. 根据列,将分为左子{D,B,E}和右子{F,C}; 3. 根据左子的后列{D,E,B}和列{D,B,E},递归求出左子的前列为{B,D,E}; 4. 根据右子的后列{F,C}和列{F,C},递归求出右子的前列为{C,F}; 5. 将根节点A和左子、右子的前列拼接起来,得到完整的前列为{A,B,D,E,C,F}。 综上所述,已知一个二叉树列和后列,可以通过递归的方式求出这棵的前列。 ### 回答3: 首先,需要明确和后的特点。 的顺是:“左子根节点右子”,即先遍左子,然后遍根节点,最后遍右子。 后的顺是:“左子右子根节点”,即先遍左子,然后遍右子,最后遍根节点。 因此,已知和后列,可以通过递归来构建这棵二叉树。需要注意的是,后列的最后一个节点一定是根节点,在找到根节点,就可以将整个列分为左右两部分,分别对左右子进行递归构建。 下面是具体的步骤: 1. 找到后列的最后一个节点,即根节点。 2. 在找到根节点的位置,将列分为左右两部分。左边的部分为左子列,右边的部分为右子列。 3. 根据左子列和后列,递归构建左子。递归的过程和原问题一样,只是输入列不同,列变成了左子列,后列变成了左子的后列。 4. 根据右子列和后列,递归构建右子。 5. 构建好左子和右子之后,根节点就可以作为整棵的根节点了,对应的值为后列的最后一个节点。然后递归地构建左子和右子的前列,并将根节点的值插入前列的最前面。 6. 最后得到的前列即为所求。 这个算法的时间复杂度为 $O(nlogn)$,其n是二叉树的节点数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值