LeetCode 145. 二叉树的后序遍历

145. 二叉树的后序遍历

Difficulty: 中等

给定一个二叉树,返回它的 _后序 _遍历。

示例:

输入: [1,null,2,3]  
   1
    \
     2
    /
   3 

输出: [3,2,1]

进阶: 递归算法很简单,你可以通过迭代算法完成吗?

Solution

迭代

# 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 postorderTraversal(self, root: TreeNode) -> List[int]:
        res, stack, pre = [], [root], None
        while stack:
            node = stack.pop()
            if node:
                res.append(node.val)
                stack.append(node.left)
                stack.append(node.right)
        return res[::-1]

递归

class Solution:
    def postorderTraversal(self, root: TreeNode) -> List[int]:
        if not root:
            return []
        else:
            l = self.postorderTraversal(root.left)
            r = self.postorderTraversal(root.right)
            d = [root.val]
            return l + r + d
上一篇:145孤荷凌寒自学第0231天_区块链第145天NFT042继续自己的NFT合约与前端


下一篇:AtCoder Beginner Contest 145