题解 | #二叉树中和为某一值的路径(三)#

//思路具体看题解。我是参考题解思路写的。
class Solution {
public:

    void solve(TreeNode* root,int sum,int &count)
    {
        if(root==nullptr)
            return;
        if(root->val==sum)
        {
            count++;
        }
        solve(root->left, sum-root->val, count);
        solve(root->right, sum-root->val, count);
    }

    int FrontOrder(TreeNode* root,int sum)
    {
        if(root==nullptr)
            return 0;
        int current=0;
        solve(root, sum, current);//处理当前节点
        int left=0;
        int right=0;
        if(root->left)
        {
            left=FrontOrder(root->left, sum);//递归两个孩子
        }
        if(root->right)
        {
            right=FrontOrder(root->right, sum);
        }
        return left+right+current;
    }

    int FindPath(TreeNode* root, int sum) {
        return FrontOrder(root, sum);
    }
};

全部评论

相关推荐

绝迹的星:前端和后端写两份简历, 如果想干全栈就直接写求职意向为全栈工程师
点赞 评论 收藏
分享
07-14 13:47
门头沟学院 Java
Lynn012:你评估好自己的位置了吗《顶尖应届》
投递小米集团等公司7个岗位
点赞 评论 收藏
分享
06-26 15:33
青岛工学院 Java
积极的秋田犬要冲国企:他现在邀请我明天面试
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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