返回
LeetCode 226. 翻转二叉树:递归反转二叉树的 Python 实现
闲谈
2023-09-10 13:46:45
在计算机科学中,二叉树是一种非线性数据结构,它具有以下特性:
- 每个节点最多有两个子节点,分别称为左子节点和右子节点。
- 每个节点都有一个值,称为节点值。
- 树中没有环。
翻转二叉树 是指将一棵二叉树的左右子树互换,从而创建一个镜像版本。
使用递归实现
我们可以使用递归算法来翻转一棵二叉树。递归算法是一种函数反复调用自身,直到满足特定终止条件。在翻转二叉树的情况下,终止条件是到达叶子节点(没有子节点的节点)。
以下是使用 Python 实现的递归算法:
def invert_tree(root):
"""
翻转一棵二叉树。
参数:
root: 二叉树的根节点。
返回:
翻转后的二叉树的根节点。
"""
if root is None:
return None
# 交换左右子树
root.left, root.right = root.right, root.left
# 对左右子树进行递归翻转
invert_tree(root.left)
invert_tree(root.right)
return root
算法复杂度
该算法的时间复杂度为 O(n),其中 n 是二叉树中的节点数。该算法需要遍历树中的每个节点,因此时间复杂度与树的大小成正比。
范例
以下是使用该算法翻转一棵二叉树的示例:
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
root = TreeNode(4)
root.left = TreeNode(2)
root.right = TreeNode(7)
root.left.left = TreeNode(1)
root.left.right = TreeNode(3)
root.right.left = TreeNode(6)
root.right.right = TreeNode(9)
invert_tree(root)
翻转后的二叉树如下所示:
4
/ \
7 2
/ \ / \
9 6 3 1
结论
翻转二叉树是一道经典的递归算法问题。使用递归算法,我们可以有效地翻转一棵二叉树,从而创建一个镜像版本。本教程提供了使用 Python 实现的递归算法,并提供了算法复杂度和范例。