LeetCode(top100)路径总和|||

路径总和|||

题目描述

给定一个二叉树,它的每个结点都存放着一个整数值。

找出路径和等于给定数值的路径总数。

路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点)。

二叉树不超过1000个节点,且节点数值范围是 [-1000000,1000000] 的整数。

题目分析

root = [10,5,-3,3,2,null,11,3,-2,null,1], sum = 8

  10
 /  \ 
5   -3

/ \ \
3 2 11
/ \
3 -2 1

返回 3。和等于 8 的路径有:

  1. 5 -> 3
  2. 5 -> 2 -> 1
  3. -3 -> 11
思路(一)

两个递归
(1)第一个递归求任意一个节点开始满足和为sum的路径条数
(2)第二个递归遍历整棵树,计算每一个节点开始满足和为sum的路径条数,最后将各节点路径数相加得到符合条件的总路径树

/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @param {number} sum
 * @return {number}
 */
var pathSum = function(root, sum) {//root为根节点, sum为规定的路径权值和
    //遍历整棵树,计算每个节点为起点的路径数
    if(!root) return 0;
    let page=findNode(root,sum);//计算从根节点开始有多少满足条件的路径数,findDown函数是求从单个节点开始满足条件的路径数
    let sum1 = pathSum(root.left, sum) //遍历左子树求符合条件的路径数,
    let sum2 = pathSum(root.right, sum) //遍历右子树求符合条件的路径数
    return page+sum1+sum2;
    
};
    //计算某一个当前节点和等于sum的路径条数
    function findNode(tNode,sum){
       if(!tNode) return 0 //若节点为空,返回0
        let flag = tNode.val === sum ? 1 : 0 // 当前节点权值刚好等于sum则算为1,否则为0
        let leftsum=findNode(tNode.left,sum-tNode.val); //剩下的权值和sum要靠左子树来凑
        let rightsum=findNode(tNode.right,sum-tNode.val); //剩下的权值和sum要靠右子树来凑
        return flag+leftsum+rightsum;// 返回符合条件的路径数
    }

二叉树原则:
(1)把当前节点要做的事做好,其他的交给递归框架,不用当前节点操作。
(2)如果当前节点会对下面的子节点有整体影响,可以通过辅助函数增长参数列表,借助参数传递信息

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值