首页 > 其他分享 >力扣 113. 路径总和 II [dfs,bfs]

力扣 113. 路径总和 II [dfs,bfs]

时间:2022-10-31 23:45:24浏览次数:80  
标签:node bfs right TreeNode dfs II que targetSum 节点

113. 路径总和 II

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

叶子节点 是指没有子节点的节点。

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

示例 2:

输入:root = [1,2,3], targetSum = 5
输出:[]

示例 3:

输入:root = [1,2], targetSum = 0
输出:[]

提示:

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

题解

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>> res;//记录所有路径
    vector<int> vcur;//记录当前路径
    void work(TreeNode* cur, int targetSum){//targetSum是当前剩余值
        vcur.emplace_back(cur->val);//放入当前节点
        if(cur->val==targetSum&&cur->left==NULL&&cur->right==NULL){//相等且是叶子节点
            res.emplace_back(vcur);
        }
        if(cur->left)
            work(cur->left,targetSum-cur->val);//targetSum更新,减去当前val
        if(cur->right)
            work(cur->right,targetSum-cur->val);
        vcur.pop_back();//当前路径达不到target就依次删除节点
    }
    vector<vector<int>> pathSum(TreeNode* root, int targetSum) {
        if(root==NULL)
            return res;
        vector<int> vcur;
        work(root,targetSum);
        return res;
    }
};

bfs

来自官方,通过queue完成广度遍历,在遍历左右子树的时候,记录子树的根节点为当前节点,如果当前和满足条件再从叶子节点去回溯路径(因为记录了父母节点,所以逆向回溯之后需要翻转路径)。

查看代码
 class Solution {
public:
    vector<vector<int>> ret;
    unordered_map<TreeNode*, TreeNode*> parent;

    void getPath(TreeNode* node) {//从叶子节点回溯,获取路径
        vector<int> tmp;
        while (node != nullptr) {
            tmp.emplace_back(node->val);
            node = parent[node];
        }
        reverse(tmp.begin(), tmp.end());//要翻转得到根节点到叶子节点的路径
        ret.emplace_back(tmp);
    }

    vector<vector<int>> pathSum(TreeNode* root, int targetSum) {
        if (root == nullptr) {
            return ret;
        }
        queue<TreeNode*> que_node;
        queue<int> que_sum;//存放当前和
        que_node.emplace(root);
        que_sum.emplace(0);

        while (!que_node.empty()) {
            TreeNode* node = que_node.front();
            que_node.pop();
            int rec = que_sum.front() + node->val;//获取当前和=之前的总和+当前节点
            que_sum.pop();

            if (node->left == nullptr && node->right == nullptr) {//如果是叶子节点判断是否满足条件
                if (rec == targetSum) {//如果满足条件就获取路径
                    getPath(node);
                }
            } 
            else {//不是叶子节点就继续放入左右子树
                if (node->left != nullptr) {
                    parent[node->left] = node;//记录当前节点node的左子树的父母节点为node
                    que_node.emplace(node->left);
                    que_sum.emplace(rec);//记录当前和
                }
                if (node->right != nullptr) {
                    parent[node->right] = node;//同理
                    que_node.emplace(node->right);
                    que_sum.emplace(rec);
                }
            }
        }
        return ret;
    }
};

标签:node,bfs,right,TreeNode,dfs,II,que,targetSum,节点
From: https://www.cnblogs.com/fudanxi/p/16846348.html

相关文章

  • php 全排列使用DFS
    字符串的全排列给定1,2,3输出:1,2,31,3,22,1,32,3,13,1,23,2,1其实是一个树形结构【】1232313......
  • 代码随想录算法训练营第二天| 977.有序数组的平方 ,209.长度最小的子数组 ,59.螺旋矩阵I
    977.有序数组的平方:https://leetcode.cn/problems/squares-of-a-sorted-array/心得:周末再写。。。publicclassSolution{publicstaticvoidmain(String[]arg......
  • [单片机][IIC/I2C][APDS9960] 手势传感器 4种手势
    /*-----------------------------------------头文件-----------------------------------------*/#include"main.h"/*-----------------------------------------宏定义......
  • 洛谷 P1464 Function(dfs+记忆化搜索)
    https://www.luogu.com.cn/problem/P1464单个返回条件的时候,直接return多个返回条件的时候,采用记忆化搜索思想,边存储边继续往下搜索中间穿插记忆化判断,如果之前有过此......
  • Linux findfs 命令
    Linux命令是对Linux系统进行管理的命令。对于Linux系统来说,无论是中央处理器、内存、磁盘驱动器、键盘、鼠标,还是用户等都是文件,Linux系统管理的命令是它正常运行的核心,与......
  • STM32 HAL IIC软模拟
    IIC(Inter-IntegratedCircuit)其实是IICBus简称,所以中文应该叫集成电路总线,它是一种串行通信总线,使用多主从架构,由飞利浦公司在1980年代为了让主板、嵌入式系统或手机用以连......
  • N76E003 单片机 IIC 软模拟
    /*-----------------------------------------头文件-----------------------------------------*/#include"iic.h"/*-----------------------------------------宏定义-......
  • 单片机 ADXL346 IIC通讯
    ​​IIC协议链接​​/*-----------------------------------------头文件-----------------------------------------*/#include"ADXL346.h"#include"math.h"/*--------......
  • ABC 275 ABCD ( dfs / 递推递归+记忆化搜索)
    https://atcoder.jp/contests/abc275/tasksA-FindTakahashi题目大意:求数组最大值的数字下标。SampleInput13508070SampleOutput12#include<bits/st......
  • [单片机框架][bsp层][cx32l003][bsp_i2c] I2C/IIC硬件配置和使用
    I2C简介I2C是双线双向的串行总线,它为设备之间数据交换提供了一种简单高效的方法。I2C标准是一个具有冲突检测机制和仲裁机制的真正意义上的多主机总线。它能防止两个或者......