每日OJ题_二叉树dfs⑥_力扣257. 二叉树的所有路径

目录

[力扣257. 二叉树的所有路径](#力扣257. 二叉树的所有路径)

解析代码


力扣257. 二叉树的所有路径

257. 二叉树的所有路径

难度 简单

给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点的路径。

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

示例 1:

复制代码
输入:root = [1,2,3,null,5]
输出:["1->2->5","1->3"]

示例 2:

复制代码
输入:root = [1]
输出:["1"]

提示:

  • 树中节点的数目在范围 [1, 100]
  • -100 <= Node.val <= 100
cpp 复制代码
/**
 * 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<string> binaryTreePaths(TreeNode* root) {

    }
};

解析代码

思路就是遍历到叶子结点就push当前路径, 到最后剪枝,不用写函数出口。

cpp 复制代码
/**
 * 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 {
    vector<string> ret;
public:
    vector<string> binaryTreePaths(TreeNode* root) {
        dfs(root, "");
        return ret;
    }

    void dfs(TreeNode* root, string path)
    {
        path += to_string(root->val); // 不可能传空root进来
        if(root->left == nullptr && root->right == nullptr)
        {
            ret.push_back(path); // 是叶子结点就push当前路径
        }
        else // 不是叶子结点就先加上箭头
        {
            path += "->";
        }
        if(root->left != nullptr) // 剪枝,此时不用写函数出口
            dfs(root->left, path);
        if(root->right != nullptr)
            dfs(root->right, path);
    }
};
相关推荐
Maỿbe7 分钟前
暴打力扣之优先级队列(堆)
算法·leetcode·职场和发展
Swift社区7 分钟前
LeetCode 438 - 找到字符串中所有字母异位词
算法·leetcode·职场和发展
jyan_敬言8 分钟前
【Docker】Kubernetes部署容器化应用程序
c++·笔记·其他·docker·容器·kubernetes·学习方法
code bean9 分钟前
【C++】全局函数和全局变量
开发语言·c++·c#
北冥湖畔的燕雀14 分钟前
二叉搜索树:高效查找与删除的实现
数据结构·c++·算法
学学学无无止境14 分钟前
力扣-位1的个数
leetcode
神仙别闹15 分钟前
基于C++实现(控制台)应用二维矩阵完成矩阵运算
开发语言·c++·矩阵
别学LeetCode16 分钟前
#leetcode# 1
leetcode
兩尛17 分钟前
矩阵中非1的数量 (2025B卷
线性代数·算法·矩阵
kupeThinkPoem18 分钟前
线段树有哪些算法?
数据结构·算法