力扣Hot100--94.二叉树的中序遍历、144.二叉树的前序遍历、145.二叉树的后序遍历

力扣Hot100--94.二叉树的中序遍历、144.二叉树的前序遍历、145.二叉树的后序遍历

要求:给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。
递归解法:

python 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        result = []
        def traversal(node):
            if node is None:
                return 
            traversal(node.left)# 左
            result.append(node.val) # 中
            traversal(node.right) # 右
        traversal(root)
        return result

迭代解法:

python 复制代码
class Solution:
    def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        result = []
        stack = []
        current = root
        while current or stack:
            if current:
                stack.append(current)
                current = current.left
            else:
                current = stack.pop()
                result.append(current.val)
                current = current.right
        return result

要求:给你二叉树的根节点 root ,返回它节点值的 前序 遍历。
递归解法:

python 复制代码
class Solution:
    def preorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        result = []
        def traversal(node):
            if node is None:
                return
            result.append(node.val)
            traversal(node.left)
            traversal(node.right)
        traversal(root)
        return result

迭代解法:

python 复制代码
class Solution:
    def preorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        if root is None:  # 一定要检查根节点是否为空
            return []
            
        result = []
        stack = [root]
        while stack:
            node = stack.pop()
            result.append(node.val)  

            if node.right:  # 先右后左
                stack.append(node.right)
            if node.left:   # 左子节点后入栈,会先出栈
                stack.append(node.left)
                

要求:给你一棵二叉树的根节点 root ,返回其节点值的 后序遍历 。
递归解法:

python 复制代码
class Solution:
    def postorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        result = []
        def traversal(node):
            if node is None:
                return 
            traversal(node.left)
            traversal(node.right)
            result.append(node.val)
        traversal(root)
        return result

迭代解法:

python 复制代码
class Solution:
    def postorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        if root is None:
            return []
        result = []
        stack = [root]
        while stack:
            node = stack.pop()
            result.append(node.val)
            if node.left:
                stack.append(node.left)
            if node.right:
                stack.append(node.right)
        return result[::-1]
相关推荐
A0_張張12 分钟前
记录一个PDF盖章工具(PyQt5 + PyMuPDF)
开发语言·python·qt·pdf
ZHang......13 分钟前
LeetCode 1114. 按序打印
java·开发语言·算法
Faker66363aaa14 分钟前
Arive-Dantu叶片识别系统:基于cascade-mask-rcnn_regnetx-400MF_fpn_ms-3x_coco模型实现_1
python
想你依然心痛16 分钟前
AI赋能编程语言挑战赛:从Python到Rust,我用AI大模型重塑开发效率
人工智能·python·rust
quikai198121 分钟前
python练习项目
python
仰泳的熊猫26 分钟前
1083 List Grades
数据结构·c++·算法·pat考试
Tan_Zhixia40 分钟前
时间复杂度判断
数据结构·c++·算法
周杰伦_Jay1 小时前
【Python开发面试题及答案】核心考点+原理解析+实战场景
开发语言·python
HyperAI超神经1 小时前
【vLLM 学习】vLLM TPU 分析
开发语言·人工智能·python·学习·大语言模型·vllm·gpu编程
雪弯了眉梢1 小时前
OpenGL(八)摄像机(Camera)
算法·图形渲染·opengl