LeetCode--257. 二叉树的所有路径(二叉树)

题目描述

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

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

示例 1:

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

示例 2:

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

提示:

  • 树中节点的数目在范围 [1, 100]
  • -100 <= Node.val <= 100

代码

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {

    public void traversal(TreeNode node, List<String> result, List<TreeNode> nodes){
        if(node == null) return;
        // 前序遍历 中间节点操作
        nodes.add(node);
        // 终止条件,遍历到叶子结点时
        if(node.left == null && node.right == null){
            // 构造string
            StringBuilder path = new StringBuilder();
            int size = nodes.size();
            for(int i=0; i<size-1; i++){
                path.append(nodes.get(i).val);
                path.append("->");
            }
            path.append(nodes.get(size-1).val);
            // 添加结果列表
            result.add(path.toString());
            return;
        }
        // 左边节点操作
        if(node.left != null){
            traversal(node.left, result, nodes);
            // 回溯弹出添加的左节点
            nodes.remove(nodes.size()-1);
        }
        // 右边节点操作
        if(node.right != null){
            traversal(node.right, result, nodes);
            // 回溯弹出添加的右节点
            nodes.remove(nodes.size()-1);
        }
        return;
    }

    public List<String> binaryTreePaths(TreeNode root) {
        List<String> result = new ArrayList<>();
        // 存放路径节点的队列
        List<TreeNode> nodes = new ArrayList<>();
        traversal(root, result, nodes);
        return result;
    }
}
相关推荐
小欣加油1 天前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly1 天前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕1 天前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei1 天前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld1 天前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi81 天前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang1 天前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby1 天前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠1 天前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力1 天前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试