113. Path Sum II

题目链接

https://leetcode.com/problems/path-sum-ii/

代码

class Solution {
public:
    void dfs(TreeNode *pNode, vector<vector<int>> &ans, vector<int> &v, int sum, int target) {
        sum += pNode->val;
        v.push_back(pNode->val);
        if (pNode->right == NULL && pNode->left == NULL) {
            if (sum == target) {
                ans.push_back(v);
            }
        } else {
            if (pNode->left != NULL) {
                dfs(pNode->left, ans, v, sum, target);
            }
            if (pNode->right != NULL) {
                dfs(pNode->right, ans, v, sum, target);
            }
        }
        
        v.pop_back();
    }

    vector<vector<int>> pathSum(TreeNode* root, int sum) {
        vector<vector<int>> ans;
        if (root == NULL) {
            return ans;
        }

        vector<int> v;
        dfs(root, ans, v, 0, sum);
        return ans;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容