题目描述

输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。

思路

二叉树的大多数问题可以使用递归来解决,本题亦如此。

首先应该有一个数组来存储当前路径上的节点值,遇到一个节点,计算出和目标值还差多少,如果还差0且当前节点已经是叶子节点,那么该路径就是符合题意的路径,否则,继续向该节点的左右节点继续递归处理下去。

代码实现

/* function TreeNode(x) {
    this.val = x;
    this.left = null;
    this.right = null;
} */
function FindPath(r, expectNumber)
{
    var listAll = [];
    var list = [];
    
    function find(r, target) {
        if(r === null)
            return;
        list.push(r.val);
        target -= r.val;
        
        if(target === 0 && r.left === null && r.right === null)
            listAll.push(Array.from(list));
        find(r.left, target);
        find(r.right, target);
        list.pop();
    }
    find(r, expectNumber)
    return listAll;
}

耳东
766 声望51 粉丝

知乎专栏:[链接]