python-leetcode 37.翻转二叉树

题目:

给定一颗二叉树的根节点root,翻转这棵二叉树,并返回根节点


方法一:递归

从根节点开始,递归地对树进行遍历,并从叶子节点先开始翻转。如果当前遍历到的节点root的左右两棵子树都已经翻转,那么我们只需要交换两棵子树的位置,即可完成以root为根节点的整棵子树的翻转。

python 复制代码
# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):
    def invertTree(self, root):
        """
        :type root: Optional[TreeNode]
        :rtype: Optional[TreeNode]
        """
        if not root:
            return root
        left=self.invertTree(root.left)
        right=self.invertTree(root.right)
        root.left,root.right=right,left
        return root

时间复杂度:O(n)遍历二叉树中的每一个节点

空间复杂度:O(n)

源自力扣官方题解

相关推荐
I_LPL6 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
颜酱6 小时前
DFS 岛屿系列题全解析
javascript·后端·算法
WolfGang0073216 小时前
代码随想录算法训练营 Day16 | 二叉树 part06
算法
2401_831824967 小时前
代码性能剖析工具
开发语言·c++·算法
Sunshine for you8 小时前
C++中的职责链模式实战
开发语言·c++·算法
qq_416018729 小时前
C++中的状态模式
开发语言·c++·算法
2401_884563249 小时前
模板代码生成工具
开发语言·c++·算法
2401_831920749 小时前
C++代码国际化支持
开发语言·c++·算法
m0_672703319 小时前
上机练习第51天
数据结构·c++·算法
ArturiaZ9 小时前
【day60】
算法·深度优先·图论