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;
    }
}
相关推荐
AI算法沐枫9 小时前
大一学生如何入门机器学习,深度学习,学习顺序如何?
人工智能·python·深度学习·学习·线性代数·算法·机器学习
codealy9 小时前
Rust 核心理论: 高并发与异步(三)
算法·rust
日月云棠9 小时前
JAVA数据结构与算法 - 基础:常用集合简述
java·算法
TYKJ0239 小时前
带宽100M但传输只有30M?你的服务器可能该换TCP算法了
后端·算法
SilentSamsara9 小时前
运算符重载:让自定义对象支持 +、[]、in 操作
开发语言·python·算法·青少年编程·pycharm
日月云棠9 小时前
JAVA数据结构与算法 - 基础:BlockingQueue
java·算法
8K超高清9 小时前
CCBN展会多图回顾
人工智能·算法·fpga开发·接口隔离原则·智能硬件
阿Y加油吧10 小时前
两道数组算法题复盘:多数元素 & 颜色分类
算法·leetcode·职场和发展
夏日听雨眠10 小时前
排序(选择排序 ,冒泡排序,归并排序)
数据结构·算法·排序算法