博客
关于我
LeetCode——Binary Tree Paths
阅读量:802 次
发布时间:2023-01-31

本文共 1608 字,大约阅读时间需要 5 分钟。

二叉树遍历问题:生成根到叶路径

问题描述

给定一个二叉树,要求返回所有从根节点到叶节点的路径。每条路径用字符串表示,路径之间用“->”连接节点值。

示例

对于以下二叉树:

1
/ \
2 3
/ \
5 ...

所有根到叶的路径为:["1->2->5", "1->3"]

方法思路

我们可以使用深度优先搜索(DFS)来遍历二叉树。当到达叶节点时,记录当前路径并将其添加到结果列表中。为了实现路径的记录和回溯,我们可以使用一个递归方法,维护一个当前路径的列表。在访问叶节点时,将路径转换为字符串并存储;在递归返回时,清理当前路径。

解决代码

import java.util.ArrayList;
import java.util.List;
public class Solution {
List
paths = new ArrayList<>();
List
path = new ArrayList<>();
public List
binaryTreePaths(TreeNode root) {
paths.clear();
path.clear();
getAllPath(root);
return paths;
}
private void getAllPath(TreeNode node) {
if (node == null) {
return;
}
path.add(node.val);
if (node.left == null && node.right == null) {
// 当前路径是完整的,生成字符串
StringBuilder sb = new StringBuilder();
for (int i = 0; i < path.size(); i++) {
if (i != 0) {
sb.append("->");
}
sb.append(path.get(i));
}
paths.add(sb.toString());
}
// 继续遍历左子树
if (node.left != null) {
getAllPath(node.left);
}
// 回溯,移除最后一个节点值
path.remove(path.size() - 1);
}
}

代码解释

  • 初始化:在binaryTreePaths方法中,清空pathspath列表,准备开始遍历。
  • 递归遍历getAllPath方法递归地遍历二叉树。首先处理当前节点,如果当前节点为null,则返回。
  • 记录路径:将当前节点的值添加到path列表中。
  • 检查叶节点:如果当前节点没有左子树和右子树,则表示到达了叶节点。此时,使用StringBuilder将路径转换为字符串,并添加到paths列表中。
  • 继续遍历:递归地处理左子树和右子树。
  • 回溯:在递归返回时,移除path列表的最后一个元素,以确保路径信息正确回溯。
  • 这种方法使用了深度优先搜索,确保先遍历完全右子树再回溯,从而正确生成所有根到叶的路径。

    转载地址:http://bqgyk.baihongyu.com/

    你可能感兴趣的文章
    NodeSession:高效且灵活的Node.js会话管理工具
    查看>>
    node~ http缓存
    查看>>
    node不是内部命令时配置node环境变量
    查看>>
    node中fs模块之文件操作
    查看>>
    Node中同步与异步的方式读取文件
    查看>>
    node中的get请求和post请求的不同操作【node学习第五篇】
    查看>>
    Node中的Http模块和Url模块的使用
    查看>>
    Node中自启动工具supervisor的使用
    查看>>
    Node入门之创建第一个HelloNode
    查看>>
    node全局对象 文件系统
    查看>>
    Node出错导致运行崩溃的解决方案
    查看>>
    Node响应中文时解决乱码问题
    查看>>
    node基础(二)_模块以及处理乱码问题
    查看>>
    node安装卸载linux,Linux运维知识之linux 卸载安装node npm
    查看>>
    node安装及配置之windows版
    查看>>
    Node实现小爬虫
    查看>>
    Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
    查看>>
    Node提示:npm does not support Node.js v12.16.3
    查看>>
    Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
    查看>>
    Node服务在断开SSH后停止运行解决方案(创建守护进程)
    查看>>