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

二叉树根节点到叶子节点的所有路径和

http://www.nowcoder.com/practice/185a87cd29eb42049132aed873273e83

/**
 * 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;

    }
};
全部评论

相关推荐

白菜小丑呜呜:Radis写错了兄弟
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务