LeetCode CodeTop 113.路径总和Ⅱ

思路:在递归的同时,额外维护从根到当前节点的元素和sum。此外,还要在递归函数的外部维护一个path列表,记录从根到当前节点路径上的所有节点。

一、递归逻辑:

1.如果当前的节点是空节点,则直接返回。

2.把当前的节点加入path,同时sum减去当前节点的值(sum初始为targetSum)。

3.如果当前的节点是叶子节点且sum == 0,那么就把路径path加入答案。

4.否则,继续递归左右子树。

5.在递归返回之前,把我们在递归开头加入的节点,也就是当前path的最后一个节点,从path中去掉(恢复现场)。为什么要这样呢,这是因为当我们递归完左子树,要递归右子树之前,path中还保留着左子树的节点。如果不及时去掉的话,会导致最终加到答案中的path,既包含左子树的节点,又包含右子树的节点,这连"路径"都算不上。

二、复杂度分析:

1.时间复杂度:O(n^2),其中n是二叉树的节点个数。首先遍历所有节点的时间复杂度是O(n),因为每个节点恰好被访问一次。对于"一条链 + 完全二叉树"这样的"扫帚型"二叉树,我们会在O(n)个叶子节点处,都去复制长为O(n)的path(res.add(new ArrayList<>(path))),所以总的时间复杂度为O(n^2)。

2.空间复杂度:O(n),返回值不计入。

附代码:

java 复制代码
class Solution {
    private List<Integer> path = new ArrayList<>();
    private List<List<Integer>> res = new ArrayList<>();
    public List<List<Integer>> pathSum(TreeNode root, int targetSum) {
        dfs(root, targetSum);
        return res;
    }

    private void dfs(TreeNode root, int sum) {
        if (root == null) {
            return;
        }
        path.add(root.val);
        sum -= root.val;
        if (root.left == null && root.right == null && sum == 0) {
            res.add(new ArrayList<>(path));
        } else {
            dfs(root.left, sum);
            dfs(root.right, sum);
        }
        path.remove(path.size() - 1);
    }
}
相关推荐
kkeeper~7 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs6668 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964139 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚9 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本9 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov11 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫11 小时前
特征工程处理
人工智能·算法·机器学习
z落落11 小时前
C#参数区别
java·算法·c#
c2385612 小时前
vector(下)
数据结构·算法
z落落12 小时前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法