首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

查找二叉树中的所有路径

是一个常见的算法问题,可以通过深度优先搜索(DFS)来解决。下面是一个完善且全面的答案:

在二叉树中查找所有路径的算法可以通过深度优先搜索(DFS)来实现。DFS是一种递归的算法,它从根节点开始遍历二叉树,并在遍历过程中记录路径。当遍历到叶子节点时,将当前路径添加到结果集中。

以下是一个示例的实现代码:

代码语言:txt
复制
class TreeNode:
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right

def find_paths(root):
    if not root:
        return []

    paths = []

    def dfs(node, path):
        if not node:
            return

        path.append(str(node.val))

        if not node.left and not node.right:
            paths.append("->".join(path))

        dfs(node.left, path)
        dfs(node.right, path)

        path.pop()

    dfs(root, [])

    return paths

在上述代码中,我们定义了一个TreeNode类来表示二叉树的节点。find_paths函数接受一个二叉树的根节点作为输入,并返回一个包含所有路径的列表。

dfs函数中,我们首先将当前节点的值添加到路径中。然后,我们检查当前节点是否为叶子节点,如果是,则将当前路径转换为字符串,并添加到结果集中。接下来,我们递归地遍历当前节点的左子树和右子树。最后,我们将当前节点的值从路径中弹出,以便继续遍历其他路径。

以下是一个示例的二叉树和对应的路径:

代码语言:txt
复制
    1
   / \
  2   3
   \
    5

对于上述二叉树,find_paths函数将返回["1->2->5", "1->3"]

这个算法的时间复杂度是O(N),其中N是二叉树中的节点数。因为我们需要遍历每个节点一次。空间复杂度是O(N),其中N是二叉树中的节点数。因为在最坏的情况下,路径的长度将达到树的高度,而树的高度最多为N。

推荐的腾讯云相关产品是云服务器(CVM)和云数据库MySQL(CDB)。云服务器提供了可靠的计算能力,可以用于部署和运行应用程序。云数据库MySQL是一种高性能、可扩展的关系型数据库服务,适用于存储和管理数据。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

二叉树所有路径

二叉树所有路径 给定一个二叉树,返回所有从根节点到叶子节点路径。 说明: 叶子节点是指没有子节点节点。...示例 输入: 1 / \ 2 3 \ 5 输出: ["1->2->5", "1->3"] 解释: 所有根节点到叶子节点路径为: 1->2->5, 1->3 题解 /**...root.right, `${tmp}->${root.right.val}`); } dfs(root, `${root.val}`) return target; }; 思路 深度优先遍历二叉树...,将路径节点拼接字符串,遍历到根节点之后将拼接字符串推入目标数组,首先如果没有节点则直接返回一个空数组,之后定义目标数组target,如果没有定义节点则返回空,如果没有左孩子以及右孩子即叶子节点,则将缓存字符串推入数组并返回结束递归...,如果存在左孩子,则向左递归并将左孩子节点值拼接到字符串并传递,如果存在右孩子,则向右递归并将右孩子节点值拼接到字符串并传递,之后启动递归,注意题目要求是字符串而不是数字,所以需要将启动时节点值转为字符串

35520
  • 二叉树:找我所有路径

    二叉树所有路径 给定一个二叉树,返回所有从根节点到叶子节点路径。 说明: 叶子节点是指没有子节点节点。 示例: ?...return; } 确定单层递归逻辑 因为是前序遍历,需要先处理中间节点,中间节点就是我们要记录路径节点,先放进path。...那么在如上代码,「貌似没有看到回溯逻辑,其实不然,回溯就隐藏在traversal(cur->left, path + "->", result); path + "->"。」...迭代法 至于非递归方式,我们可以依然可以使用前序遍历迭代方式来模拟遍历路径过程,对该迭代方式不了解同学,可以看文章二叉树:听说递归能做,栈也能做!...和二叉树:前后序迭代方式写法就不能统一一下么?。 这里除了模拟递归需要一个栈,同时还需要一个栈来存放对应遍历路径

    65920

    LeetCode102|二叉树所有路径

    0x01,问题简述 给定一个二叉树,返回所有从根节点到叶子节点路径。 说明: 叶子节点是指没有子节点节点。...0x02,示例 示例: 输入: 1 / \ 2 3 \ 5 输出: ["1->2->5", "1->3"] 解释: 所有根节点到叶子节点路径为: 1->2->5,...1->3 0x03,题解思路 基于队列数据结构进行解决 0x04,题解程序 import java.util.ArrayList; import java.util.LinkedList;...具体见下文链接内容,文章汇总【JDK源码分析部分】,JDK相对于java编程人员是再熟悉不过了,随时可见,当初自己之所以分析JDK源码是因为工作需要这部分内容沉淀,所以利用了一部分时间,慢慢输出了这么多内容...,帮助了自己很多,自己在那其中也深深感到JDK源码重要性

    26710

    Leetcode No.257 二叉树所有路径

    一、题目描述 给定一个二叉树,返回所有从根节点到叶子节点路径。 说明: 叶子节点是指没有子节点节点。...示例: 输入: 1 / \ 2 3 \ 5 输出: ["1->2->5", "1->3"] 解释: 所有根节点到叶子节点路径为: 1->2->5, 1->3 二、解题思路...在深度优先搜索遍历二叉树时,我们需要考虑当前节点以及它孩子节点。 如果当前节点不是叶子节点,则在当前路径末尾添加该节点,并继续递归遍历该节点每一个孩子节点。...如果当前节点是叶子节点,则在当前路径末尾添加该节点后我们就得到了一条从根节点到叶子节点路径,将该路径加入到答案即可。 如此,当遍历完整棵二叉树以后我们就得到了所有从根节点到叶子节点路径。...除答案数组外我们需要考虑递归调用栈空间。在最坏情况下,当二叉树每个节点只有一个孩子节点时,即整棵二叉树呈一个链状,此时递归层数为 N,此时每一层 path 变量空间代价总和为 O( ?

    1.3K20

    二叉树——257. 二叉树所有路径

    1 题目描述 给你一个二叉树根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点路径。 叶子节点 是指没有子节点节点。...在深度优先搜索遍历二叉树时,我们需要考虑当前节点以及它孩子节点。 如果当前节点不是叶子节点,则在当前路径末尾添加该节点,并继续递归遍历该节点每一个孩子节点。...如果当前节点是叶子节点,则在当前路径末尾添加该节点后我们就得到了—条从根节点到叶子节点路径,将该路径加入到答案即可。 如此,当遍历完整棵二叉树以后我们就得到了所有从根节点到叶子节点路径。...在最坏情况下,当二叉树每个节点只有一个孩子节点时,即整棵二叉树呈—个链状,此时递归层数为N,此时每一层path变量空间代价总和为 空间复杂度为o(N²)。...我们维护—个队列,存储节点以及根到该节点路径。一开始这个队列里只有根节点。在每一步迭代,我们取出队列首节点,如果它是叶子节点,则将它对应路径加入到答案

    30630

    leetcode树之二叉树所有路径

    序 本文主要记录一下leetcode树之二叉树所有路径 binary-tree-8-638.jpg 题目 给定一个二叉树,返回所有从根节点到叶子节点路径。说明: 叶子节点是指没有子节点节点。...示例:输入: 1 / \2 3 \ 5输出: ["1->2->5", "1->3"]解释: 所有根节点到叶子节点路径为: 1->2->5, 1->3来源:力扣(LeetCode)链接...,设计了solve方法,方法有个集合类型参数用于收集路径,另外还有一个参数用于表示路径前缀;每次执行solve方法都将当前节点val追加在路径前缀,在节点为叶子节点时,将前缀添加到result并返回...;若不为叶子节点则将 ->拼接到路径前缀,递归其左右子节点。...doc 二叉树所有路径

    24600

    二叉树所有路径:不止递归,还有回溯

    二叉树所有路径 题目地址:https://leetcode-cn.com/problems/binary-tree-paths/ 给定一个二叉树,返回所有从根节点到叶子节点路径。...return; } 确定单层递归逻辑 因为是前序遍历,需要先处理中间节点,中间节点就是我们要记录路径节点,先放进path。...那么在如上代码,貌似没有看到回溯逻辑,其实不然,回溯就隐藏在traversal(cur->left, path + "->", result); path + "->"。...迭代法 至于非递归方式,我们可以依然可以使用前序遍历迭代方式来模拟遍历路径过程,对该迭代方式不了解同学,可以看文章二叉树:听说递归能做,栈也能做!和二叉树:前后序迭代方式统一写法。...:找我所有路径

    1.3K61

    ​LeetCode刷题实战257:二叉树所有路径

    算法重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !...今天和大家聊问题叫做 二叉树所有路径,我们先来看题面: https://leetcode-cn.com/problems/binary-tree-paths/ Given the root of a...给定一个二叉树,返回所有从根节点到叶子节点路径。说明: 叶子节点是指没有子节点节点。 ? 解题 ? /** * Definition for a binary tree node....= null){ helper(root.right, s + "->", list); } } } 好了,今天文章就到这里,如果觉得有所收获...,请顺手点个在看或者转发吧,你们支持是我最大动力 。

    21610

    LeetCode - 所有可能路径

    ,找到所有从 0 到 n-1 路径并输出(不要求按顺序) 二维数组第 i 个数组单元都表示有向图中 i 号结点所能到达下一些结点(译者注:有向图是有方向,即规定了a→b你就不能从b→a)空就是没有下一个结点了...提示: 结点数量会在范围 [2, 15] 内。 你可以把路径以任意顺序输出,但在路径结点顺序必须保证。...来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/all-paths-from-source-to-target 著作权归领扣网络所有。...从第0个节点开始,如果当前是最后一个节点,也就是n等于数组大小,那么就返回一条路径;否则,为每条路径都添加当前节点访问; 最后返回List就是最后所有的0到n-1路径。...} /** * 实际处理 * * @param graph 图 * @param n 当前是第几个节点 * @return 路径

    73630
    领券