美文网首页
二叉树中和为某一值的路径

二叉树中和为某一值的路径

作者: Bing_o_o | 来源:发表于2019-08-21 22:55 被阅读0次

    题目描述

    输入一颗二叉树的根节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前)

    Java实现

    import java.util.ArrayList;
    
    class TreeNode {
        int val;
        TreeNode left;
        TreeNode right;
    
        public TreeNode(int val) {
            this.val = val;
        }
    }
    
    public class Solution {
        private ArrayList<ArrayList<Integer>> ret = new ArrayList<>();
    
        private void backtracking(TreeNode root, int target, ArrayList<Integer> path) {
            if(root == null)
                return;
            path.add(root.val);
            target -= root.val;
            if(target == 0 && root.left == null && root.right == null) {
                ret.add(new ArrayList<>(path));
            } else {
                backtracking(root.left, target, path);
                backtracking(root.right, target, path);
            }
            path.remove(path.size() - 1);
        }
    
        public ArrayList<ArrayList<Integer>> FindPath(TreeNode root, int target) {
            backtracking(root, target, new ArrayList<>());
            return ret;   
        }
    }
    

    相关文章

      网友评论

          本文标题:二叉树中和为某一值的路径

          本文链接:https://www.haomeiwen.com/subject/jzbwsctx.html