LeetCode 113. 路径总和 II && 深度优先搜索

题目要求

原题目链接:113. 路径总和 II

题目要求如下:

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

叶子节点 是指没有子节点的节点。

示例如下:

示例1:
在这里插入图片描述
输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]
示例2:
在这里插入图片描述
输入:root = [1,2,3], targetSum = 5
输出:[]

TreeNode定义如下:

public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;
    TreeNode() {}
    TreeNode(int val) { this.val = val; }
    TreeNode(int val, TreeNode left, TreeNode right) {
        this.val = val;
        this.left = left;
        this.right = right;
    }
}

解法1:深度优先搜索

思路

直接深度优先搜索,遍历每一个节点,并且对访问路径进行记录,当访问到叶子节点时,判断从根节点到当前叶子节点的路径和是否与目标和相等,相等则添加到一个集合中,并继续寻找其他可能路径。

完整AC代码

class Solution {
    Deque<Integer> path = new LinkedList<Integer>();
    List<List<Integer>> ans = new LinkedList<List<Integer>>();
    public List<List<Integer>> pathSum(TreeNode root, int targetSum) {
        dfs(root, targetSum);
        return ans;
    }

    public void dfs(TreeNode root, int sum){
        if(root == null) return;
        // 路径记录
        path.addLast(root.val);
        // 是叶子节点且路径和与targetSum相等 则将当前路径添加到ans集合中
        if(root.left == null && root.right == null && sum == root.val)ans.add(new LinkedList<Integer>(path));
        dfs(root.left, sum - root.val);
        dfs(root.right, sum - root.val);
        
        path.pollLast();
    }
}

复杂度分析

时间复杂度:O(N²),其中N是二叉树的总节点数。首先DFS会访问树中的每个节点一次,时间复杂度等同一次树的遍历O(N),当找到符合题目要求的路径时,向最终返回集合添加新元素的操作实际复杂度也为O(N) ,此处可以参见LinkedList源码,故总时间复杂度O (N²)。
空间复杂度:O(N),其中N是二叉树的总节点数。空间复杂度取决于递归使用的栈空间开销,栈元素最多不会查过树的总节点数。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

7rulyL1ar

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值