二叉树的先序遍历序列为ABCDEF,中序遍历序列为CBDAEF,则后序遍历序列为
时间: 2024-05-29 07:14:12 浏览: 115
根据先序遍历序列找到根节点为A,再在中序遍历序列中找到A的位置,可以将中序遍历序列分为CBDA和EF两部分。由于是二叉树,因此先序遍历序列中B和C一定是A的左右子节点,同理D、E、F一定是A的右子树的节点。
接下来可以递归处理左子树和右子树。左子树的先序遍历序列为BCD,中序遍历序列为CBD,可以依此求得左子树的后序遍历序列DCB。右子树的先序遍历序列为EF,中序遍历序列为EAF,可以依此求得右子树的后序遍历序列AFE。
因此,整棵树的后序遍历序列为DCBAFE。
相关问题
二叉树的先序遍历序列为ABCDEF,中序遍历序列为CBDAEF,则后序遍历序列为( )。
根据先序遍历序列和中序遍历序列可以重构出该二叉树,进而得到后序遍历序列。具体地,根据先序遍历序列可以得到根节点为A,根据中序遍历序列可以得到左子树的中序遍历序列为CBD,右子树的中序遍历序列为AEF。接下来递归处理左右子树,根据左子树的先序遍历序列ABC和中序遍历序列CBD可以得到左子树的后序遍历序列CDAB;根据右子树的先序遍历序列DEF和中序遍历序列AEF可以得到右子树的后序遍历序列FEBA。因此,整棵树的后序遍历序列为CDABFEA。
已知一棵二叉树的前序遍历序列为ABCDEF,中序遍历序列为CBDAEF,请还原这棵二叉树?这棵二叉树的后序遍历结果是多少
已知一棵二叉树的前序遍历序列为ABCDEF,中序遍历序列为CBDAEF,可以还原出如下的二叉树:
```
A
/ \
B E
/ \ \
C D F
```
该二叉树的后序遍历序列为:CDCBFEA。
下面是Python代码实现:
```python
# 定义二叉树节点类
class TreeNode:
def __init__(self, val=0):
self.val = val
self.left = None
self.right = None
# 根据前序遍历序列和中序遍历序列还原二叉树
def buildTree(preorder, inorder):
if not preorder or not inorder:
return None
root_val = preorder[0]
root = TreeNode(root_val)
mid = inorder.index(root_val)
root.left = buildTree(preorder[1:mid+1], inorder[:mid])
root.right = buildTree(preorder[mid+1:], inorder[mid+1:])
return root
# 后序遍历二叉树
def postorderTraversal(root):
if not root:
return []
res = []
stack = [(root, False)]
while stack:
node, visited = stack.pop()
if not node:
continue
if visited:
res.append(node.val)
else:
stack.append((node, True))
stack.append((node.right, False))
stack.append((node.left, False))
return res
# 测试
preorder = ['A', 'B', 'C', 'D', 'E', 'F']
inorder = ['C', 'B', 'D', 'A', 'E', 'F']
root = buildTree(preorder, inorder)
print(postorderTraversal(root)) # ['C', 'D', 'B', 'F', 'E', 'A']
```
阅读全文