力扣 113. 路径总和 II

该文介绍了一种使用C++和递归法解决LeetCode上的路径之和II问题的方法。通过前序遍历二叉树,遍历每个节点并计算路径和,当路径和等于目标和时,将路径保存到结果中。代码中定义了一个Solution类,包含一个getlujing函数用于递归遍历,以及pathSum函数作为主入口。
摘要由CSDN通过智能技术生成

题目来源:https://leetcode.cn/problems/path-sum-ii/description/

 

C++题解:采用递归法,前序遍历,遍历每个叶子节点,路径和满足条件则将该路径保存下来。

class Solution {
public:
    void getlujing(TreeNode* node, int targetSum, int sumtmp, vector<int> lujing, vector<vector<int>>& result) {
        sumtmp = sumtmp + node->val;
        lujing.push_back(node->val);
        if(node->left == nullptr && node->right == nullptr) {
            if(sumtmp == targetSum) result.push_back(lujing);
            return;
        }
        if(node->left) getlujing(node->left, targetSum, sumtmp, lujing, result);
        if(node->right) getlujing(node->right, targetSum, sumtmp, lujing, result);
    }
    vector<vector<int>> pathSum(TreeNode* root, int targetSum) {
        vector<vector<int>> result;
        vector<int> lujing;
        int sumtmp = 0;
        if(!root) return result;
        getlujing(root, targetSum, sumtmp, lujing, result);
        return result;
    }
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值