假设一个非空二叉树采用二叉链储存结构,所有结点值为单个字符且不相同。编写一个实验程序,将一棵二叉树bt的左右子树进行交换,要求不破坏原二叉树,并采用相关数据进行测试。
时间: 2023-06-10 08:03:40 浏览: 182
很高兴为您解答问题!
以下是一种可能的实现方式:
```python
class TreeNode:
def __init__(self, val=None, left=None, right=None):
self.val = val
self.left = left
self.right = right
def mirror(root):
if not root:
return
root.left, root.right = root.right, root.left
mirror(root.left)
mirror(root.right)
if __name__ == '__main__':
# 构建一棵二叉树
root = TreeNode('a')
root.left, root.right = TreeNode('b'), TreeNode('c')
root.left.left, root.left.right = TreeNode('d'), TreeNode('e')
root.right.left, root.right.right = TreeNode('f'), TreeNode('g')
# 打印原二叉树
print('原二叉树:')
def preorder(root):
if not root:
return
print(root.val, end=" ")
preorder(root.left)
preorder(root.right)
preorder(root)
print()
# 左右子树进行交换
mirror(root)
# 打印交换后的二叉树
print('交换后的二叉树:')
preorder(root)
print()
```
该程序中,我们定义了一个 `TreeNode` 类来表示二叉树的结点,其中包含了该结点的值、左子结点和右子结点。实现函数 `mirror`,用于左右子树交换,该函数使用递归的方式,先将当前结点的左右子树交换,然后递归交换其左右子树。
在 `main` 函数中,我们构建了一棵二叉树,并将其打印出来,然后调用 `mirror` 函数进行左右子树的交换,最后再次打印出交换后的二叉树。
当输入一棵二叉树时,该程序可以正确地进行左右子树的交换,而且不会对原二叉树造成破坏。我们可以用一些简单的测试用例进行测试,例如:
```
原二叉树:
a b d e c f g
交换后的二叉树:
a c g f b e d
```
感谢您的提问,希望我的解答可以帮助到您!
阅读全文