题解 | #二叉树根节点到叶子节点的所有路径和#

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

http://www.nowcoder.com/practice/840dd2dc4fbd4b2199cd48f2dadf930a

/**
 * struct TreeNode {
 *    int val;
 *    struct TreeNode *left;
 *    struct TreeNode *right;
 * };
 */

class Solution {
public:
    /**
     * 
     * @param root TreeNode类 
     * @return int整型
     */
    int preOrder(TreeNode* root, int sum) { // sum 存储路径总和
        if(!root)
            return 0;
        sum = sum * 10 + root->val; // 当路径中节点不为空就将节点加入进sum
        if(!root->left && !root->right) // 当当前节点没有子树时,返回当前这一路径的路径和
            return sum;
        return preOrder(root->left, sum) + preOrder(root->right, sum); // 返回左子树路径和 + 右子树路径和
    }
    int sumNumbers(TreeNode* root) {
        // write code here
        int res = 0;
        res = preOrder(root, 0);
        return res;

    }
};
全部评论

相关推荐

点赞 评论 收藏
分享
牛舌:如果我不想去,不管对方给了多少,我一般都会说你们给得太低了。这样他们就会给下一个offer的人更高的薪资了。
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务