【LeetCode剑指offer34】二叉树中和为某一值的路径(dfs回溯)

简介: 树中节点总数在范围 [0, 5000] 内-1000 <= Node.val <= 1000

一、题目

image.png

提示:


树中节点总数在范围 [0, 5000] 内

-1000 <= Node.val <= 1000

-1000 <= targetSum <= 1000

二、思路

回溯思想,dfs首先将当前的元素加入,然后判断到目前为止的temp数组是否满足sum=target的一种情况,如果不满足则继续递归遍历左子树和右子树。注意!!!当左子树和右子树都为空时,即当前节点为叶子结点了,到底的判断完了!!就把temp数组刚才存的最后一个(叶子)节点取出,下一步dfs递归刚才这个节点的【兄弟节点】!!


类似的回溯题目:

【LeetCode46】全排列(DFS)

【LeetCode39】组合总和(回溯法)

【LeetCode494】目标和(暴搜dfs或dp)

【LeetCode17】电话号码的字母组合(DFS回溯)


三、代码

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<vector<int>>ans;
    vector<int>temp;
    int sum = 0;
    vector<vector<int>> pathSum(TreeNode* root, int target) {
        dfs(root, target);
        return ans;
    }
    void dfs(TreeNode* root, int target){
        if(root == NULL){
            return;
        }
        temp.push_back(root->val);
        sum += root->val;
        //到根节点了,并且sum满足条件
        if(root->left == NULL && root->right == NULL && sum == target){
            ans.push_back(temp);
        }
        dfs(root->left, target);
        dfs(root->right, target);
        //当左右孩子都为空的节点时,就把temp里最后的节点弹出,dfs弹出节点的兄弟节点
        temp.pop_back();
        sum -= root->val;
    }
};
相关文章
|
7天前
|
存储
【LeetCode】剑指 Offer 54. 二叉搜索树的第k大节点
【LeetCode】剑指 Offer 54. 二叉搜索树的第k大节点
16 1
|
7天前
【力扣刷题】二叉树的中序遍历、二叉树的最大深度、翻转二叉树、对称二叉树
【力扣刷题】二叉树的中序遍历、二叉树的最大深度、翻转二叉树、对称二叉树
14 0
|
10天前
|
存储 Java
JAVA数据结构刷题 -- 力扣二叉树
JAVA数据结构刷题 -- 力扣二叉树
16 0
|
11天前
[LeetCode]—— 226——翻转二叉树
[LeetCode]—— 226——翻转二叉树
|
11天前
[LeetCode]——965——单值二叉树
[LeetCode]——965——单值二叉树
|
11天前
LeetCode——101——对称二叉树
LeetCode——101——对称二叉树
35 12
|
11天前
|
存储
LeetCode———144—— 二叉树的前序遍历
LeetCode———144—— 二叉树的前序遍历
|
7天前
|
索引
【力扣刷题】两数求和、移动零、相交链表、反转链表
【力扣刷题】两数求和、移动零、相交链表、反转链表
15 2
【力扣刷题】两数求和、移动零、相交链表、反转链表
|
6天前
|
算法
"刷题记录:哈希表+双指针 | leetcode-2465. 不同的平均值数目 "
该文段是一篇关于编程题目的解答,主要讨论如何找到数组中所有不同平均值的个数。作者首先使用排序和哈希集来解决,将数组转为列表排序后,通过双指针计算平均值并存入哈希集以去重。然后,作者发现可以优化方案,通过双指针在排序后的数组中直接计算两数之和,用哈希集记录不重复的和,从而避免实际计算平均值,提高了算法效率。最终代码展示了这两种方法。
15 0
|
7天前
|
索引
【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
13 0