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

//思路具体看题解。我是参考题解思路写的。
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);
    }
};

全部评论

相关推荐

无敌虾孝子:喜欢爸爸还是喜欢妈妈
点赞 评论 收藏
分享
牛客410815733号:这是什么电影查看图片
点赞 评论 收藏
分享
11-27 17:08
已编辑
牛客_产品运营部_私域运营
腾讯 普通offer 24k~26k * 15,年包在36w~39w左右。
点赞 评论 收藏
分享
评论
1
1
分享
牛客网
牛客企业服务