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

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

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

思路

  • DFS
  • “恢复现场”意思是,在递归之后,说明“递归的一条路走到头了”,path长度为n-1,此时要把path中的最后一个值去掉,path缩短为n-1,再进行其他路径测试

代码

class Solution {
public:
    vector<vector<int> > res;
    vector<int> path;

    vector<vector<int>> pathSum(TreeNode* root, int sum) {

        recur(root, sum);
        return res;

    }

    void recur(TreeNode* root, int sum) {
        // 1. 终止条件
        if(root == NULL) return;
        // 2. 执行内容
        path.push_back(root->val);
        sum -= root->val;
        if(sum==0 && root->left==NULL && root->right==NULL) {
            // vector<int> path_temp(path);
            res.push_back(path);
        }
        // 3. 递归    
        recur(root->left, sum);
        recur(root->right, sum);

        //恢复现场
        path.pop_back();

    }
};
全部评论

相关推荐

06-26 17:24
已编辑
宁波大学 Java
一口洪烧肉:哈哈哈哈哈哈哈哈哈哈哈硬要啊
点赞 评论 收藏
分享
Ncsbbss:又想干活又想要工资,怎么什么好事都让你占了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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