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

//思路具体看题解。我是参考题解思路写的。
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-05 16:23
门头沟学院 Java
mengnankk:我投了300,约了5 6个面试。感觉项目写的太多了。一个项目就写五六个亮点,不是把整个项目的功能描述下。其他的没啥,简历看起来有点长
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 13:15
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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