144. Binary Tree Preorder Traversal

DFS preorder

一般都是 recursively比较快,这题大概是因为要传递res,比较下来竟然是iteratively快。

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

Last updated

Was this helpful?