算法:二叉树的所有路径

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

一、背景介绍

二、解题步骤

总结


提示:以下是本篇文章正文内容,下面案例可供参考

一、背景介绍

给定一个二叉树,返回所有从根节点到叶子节点的路径。

复制代码
输入:

   1
 /   \
2     3
 \
  5
输出: ["1->2->5", "1->3"]
解释: 所有根节点到叶子节点的路径为: 1->2->5, 1->3

二、解题步骤

解题思路:

我们可以逆向推理,如果该二叉树有N个叶子节点,是不是意味着要做N次路径拼接添加操作。

单次的路径拼接操作,由叶子节点的值和父节点的路径组成,父节点的路径又由它的父节点的路径组成。也就是说我们从根节点出发,分别朝左子树和右子树遍历,只要当前节点不是叶子节点,那么就将当前节点的信息放入父节点的路径,直到遇到叶子节点,然后完成最后的组装。

这个题很适合用递归的思路解答。

代码示例:

复制代码
@Test
public void test(TreeNode root) {
    List<String> answer = new ArrayList<>();
    searchBT(root, "", answer);
    System.out.println(JSON.toJSONString(answer));
}

private void searchBT(TreeNode root, String path, List<String> answer) {
    if (root.left == null && root.right == null) {
        answer.add(path + root.val);
    }
    if (root.left != null) {
        searchBT(root.left, path + root.val + "->", answer);
    }
    if (root.right != null) {
        searchBT(root.right, path + root.val + "->", answer);
    }
}

path + root.val + "->" 父节点路径拼接

path + root.val 叶子节点全路径组装

这是两个关键点。


总结

每天进步一点点!

相关推荐
星空露珠6 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
笨笨没好名字6 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
手写码匠6 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc
luj_17686 小时前
草酸与烟酸对消化及糖代谢的影响解析
服务器·c语言·开发语言·经验分享·算法
青风977 小时前
16-ADAPTRACK:基于自适应阈值的多目标跟踪匹配算法
人工智能·算法·目标跟踪
汤姆yu7 小时前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot
Sam09277 小时前
【AI 算法精讲 14】TF-IDF:词频与逆文档频率
人工智能·python·算法·ai
AI科技星7 小时前
拓扑生命系统确定性理论:基于32维流形的遗传密码起源与衰老动力学( 中英双语顶刊终稿·标准数学符号)
开发语言·网络·人工智能·算法·机器学习·乖乖数学·全域数学
编程圈子8 小时前
电机驱动开发学习18. SVPWM空间矢量调制算法详解与实现
驱动开发·学习·算法
大鱼>8 小时前
机器学习基础:从零理解核心概念与算法分类
算法·机器学习·分类