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

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

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();

    }
};
全部评论

相关推荐

Jcwemz:中软证书写单行,考了什么学了什么相关技术栈的内容就说自己会什么, 没实习就包装实习简历,将项目经历写成实习做的,项目时间拉长,项目成果具体化,测试的项目成果无非就是写了多少用例查出了多少bug,重要的不是实习了多久,而是你会多少东西,你能表达的就都是你的。 cet4,随便找个地方标上就好了,不用写单行。 粗略建议,我也不在行,觉得对的可以采纳
实习,投递多份简历没人回...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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