题目信息
-
题目:剑指 Offer 34. 二叉树中和为某一值的路径
-
时间: 2020-09-07
-
题目链接:Leetcode
-
tag:深度优先搜索 回溯法
-
难易程度:中等
-
题目描述:
输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径。从树的根节点开始往下一直到叶节点所经过的节点形成一条路径。
示例:
给定如下二叉树,以及目标和 sum = 22
,
1 | 5 |
返回:
1 | [ |
提示
1 | 1.节点总数<=10000 |
解题思路
本题难点
本问题是典型的二叉树方案搜索问题,使用回溯法解决,其包含 先序遍历 + 路径记录 两部分。
具体思路
- 先序遍历:按照 “根、左、右” 的顺序,遍历树的所有节点。
- 路径记录: 在先序遍历中,记录从根节点到当前节点的路径。当路径为 ① 根节点到叶节点形成的路径 且 ② 各节点值的和等于目标值
sum
时,将此路径加入结果列表。
值得注意的是,记录路径时若直接执行 res.append(path) ,则是将 path 对象加入了 res ;后续 path 改变时, res 中的 path 对象也会随之改变。
代码
1 | class Solution { |
复杂度分析:
- 时间复杂度 O(N) : N 为二叉树的节点数,先序遍历需要遍历所有节点。
- 空间复杂度 O(N) : 最差情况下,即树退化为链表时,
path
存储所有树节点,使用 O(N) 额外空间。