226. 翻转二叉树 - 力扣(LeetCode)

方法1:递归法

  • 时间:O(n) ------ 每个节点访问一次
  • 空间:O(h) ------ 递归栈深度(h 为树高,最坏 O(n),平均 O(log n))
python 复制代码
# encoding = utf-8
# 开发者:Alen
# 开发时间: 12:24 
# "Stay hungry,stay foolish."

# 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 None

        root.left, root.right = root.right, root.left

        self.invertTree(root.left)
        self.invertTree(root.right)
        return root

方法2:迭代法(使用栈)

  • 时间:O(n)
  • 空间:O(h) ------ 栈最多存 h 个节点
python 复制代码
# encoding = utf-8
# 开发者:Alen
# 开发时间: 12:24 
# "Stay hungry,stay foolish."

# 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 None

        stack = [root]
        while stack:
            node = stack.pop()

            node.left, node.right = node.right, node.left

            if node.left:
                stack.append(node.left)
            if node.right:
                stack.append(node.right)
        return root

结果

解题思路

相关推荐
条tiao条19 小时前
KMP 算法详解:告别暴力匹配,让字符串匹配 “永不回头”
开发语言·算法
干啥啥不行,秃头第一名19 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
zzh9407720 小时前
Gemini 3.1 Pro 硬核推理优化剖析:思维织锦、动态计算与国内实测
算法
2301_8073671920 小时前
C++中的解释器模式变体
开发语言·c++·算法
愣头不青20 小时前
617.合并二叉树
java·算法
MIUMIUKK21 小时前
双指针三大例题
算法
灵感__idea21 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法
2301_819414301 天前
C++与区块链智能合约
开发语言·c++·算法
Zaly.1 天前
【Python刷题】LeetCode 1727 重新排列后的最大子矩阵
算法·leetcode·矩阵
做怪小疯子1 天前
蚂蚁暑期 319 笔试
算法·职场和发展