• 【剑指Offer】34.二叉树中和为某一值的路径(二)


    题目

    输入一颗二叉树的根节点root和一个整数expectNumber,找出二叉树中结点值的和为expectNumber的所有路径。

    1.该题路径定义为从树的根结点开始往下一直到叶子结点所经过的结点

    2.叶子节点是指没有子节点的节点

    3.路径只能从父节点到子节点,不能从子节点到父节点

    4.总节点数目为n

    如二叉树root为{10,5,12,4,7},expectNumber为22

    则合法路径有[[10,5,7],[10,12]]

    数据范围:

    树中节点总数在范围 [0, 5000] 内

    -1000 <= 节点值 <= 1000

    -1000 <= expectNumber <= 1000

    示例1

    输入:{10,5,12,4,7},22

    返回值:[[10,5,7],[10,12]]

    说明:返回[[10,12],[10,5,7]]也是对的

    示例2

    输入:{10,5,12,4,7},15

    返回值:[]

    示例3

    输入:{2,3},0

    返回值:[]

    示例4

    输入:{1,3,4},7

    返回值:[]

    解答

    源代码

    1. import java.util.*;
    2. /*
    3. * public class TreeNode {
    4. * int val = 0;
    5. * TreeNode left = null;
    6. * TreeNode right = null;
    7. * public TreeNode(int val) {
    8. * this.val = val;
    9. * }
    10. * }
    11. */
    12. public class Solution {
    13. /**
    14. * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
    15. *
    16. *
    17. * @param root TreeNode类
    18. * @param target int整型
    19. * @return int整型ArrayList>
    20. */
    21. public ArrayList> FindPath(TreeNode root, int target) {
    22. // write code here
    23. ArrayList> res = new ArrayList>();
    24. ArrayList combine = new ArrayList<>();
    25. dfs(root, target, res, new ArrayList());
    26. return res;
    27. }
    28. public void dfs(TreeNode root, int target, ArrayList> res, ArrayList combine) {
    29. if (root == null) {
    30. return;
    31. }
    32. combine.add(root.val);
    33. if (root.left == null && root.right == null && root.val == target) {
    34. res.add(new ArrayList<>(combine));
    35. }
    36. dfs(root.left, target - root.val, res, combine);
    37. dfs(root.right, target - root.val, res, combine);
    38. combine.remove(combine.size() - 1);
    39. return;
    40. }
    41. }

    总结

    利用递归,深度优先遍历二叉树,当遍历到叶结点时,判断当前路径和是否等于指定数字,若是则将该路径添加进最终需要返回的结果中。这里需要注意,应该使用的是 res.add(new ArrayList<>(combine)) 而不是 res.add(combine) ,否则结果中的各个路径会随 combine 的增删变化。

  • 相关阅读:
    经验风险最小化与极大似然估计概念
    项目(交友)
    Packet Tracer模拟一次简单的HTTP请求
    实现本地访问云主机,以及在云主机搭建FTP站点
    zabbix监控实战
    ES6中 Promise 概念、基本用法和封装ajax(json数据使用)
    YOLOv5分类任务——手势识别
    MyBatis-Plus多数据源——如何在一个项目中使用多个MySQL数据库
    MATLAB(5)绘图
    PowerBI中导出数据方法汇总
  • 原文地址:https://blog.csdn.net/qq_57438473/article/details/133971183