二叉树根节点到叶子节点的和为指定值的路径

图片说明

/*
 * function TreeNode(x) {
 *   this.val = x;
 *   this.left = null;
 *   this.right = null;
 * }
 */

/**
  * 
  * @param root TreeNode类 
  * @param sum int整型 
  * @return int整型二维数组
  */
function pathSum( root ,  sum ) {
    // write code here
    if(!root) return []//false
    var result = []
    function dfs(root,cursum,path){
        if(!root) return
        if(root){
            cursum += root.val
            path.push(root.val)
            if(cursum==sum&&!root.left&&!root.right){
                result.push(path)
                return
            }
            if(root.left) dfs(root.left,cursum,[...path])
            if(root.right) dfs(root.right,cursum,[...path])
        }
    }
    dfs(root,0,[])
    return result;
    //判断是否存在
    //return result.length==0? false:true;
}
module.exports = {
    pathSum : pathSum
};
树算法 文章被收录于专栏

树相关算法

全部评论

相关推荐

ohs的小木屋:比不少实习待遇高了
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
头顶尖尖的程序员:我是26届的不太懂,25届不应该是找的正式工作吗?为什么还在找实习?大四还实习的话是为了能转正的的岗位吗
点赞 评论 收藏
分享
07-02 18:09
门头沟学院 Java
苍穹外卖和谷粒商城这俩是不是烂大街了,还能做吗?
想去重庆的鸽子在吐槽:你不如把这俩做完自己搞明白再优化点再来问 何必贩卖焦虑
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务