二叉树的遍历(DFS: 前序遍历/中序遍历/后序遍历; BFS: 层序遍历)
概述
- 前序遍历/中序遍历/后序遍历
- 利用栈实现DFS
- 有递归版本和迭代版本,迭代是显式地实现了递归栈
- 层序遍历
- 利用队列实现BFS
- 遍历每一层的时候记录长度或者设置dummy node来区别层
力扣
144二叉树的前序遍历
94二叉树的中序遍历
145二叉树的后序遍历
102二叉树的层序遍历
前序遍历/中序遍历/后序遍历
# 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
层序遍历
示例:
二叉树:[3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回其层序遍历结果:
[
[3],
[9,20],
[15,7]
]
class Solution:
def levelOrder(self, root: TreeNode) -> List[List[int]]:
queue = collections.deque([root])
res