二叉树 | 二叉树的前序遍历问题

二叉树的前序遍历问题描述

提供二叉树的根节点 root ,返回它节点值的 前序遍历。

二叉树的前序遍历是一种深度优先遍历(DFS)的方式,其遍历顺序为:先访问根节点,然后递归地对左子树进行前序遍历,最后递归地对右子树进行前序遍历。

二叉树的定义

在Java中,二叉树的定义可以通过一个类表示。以下是一个简单的二叉树节点类的定义:

java 复制代码
public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;

    public TreeNode(int val) {
        this.val = val;
    }
}

使用这个定义,可以构建任意形状的二叉树,例如:

java 复制代码
/*
 * 示例二叉树:
 *      1
 *     / \
 *    2   3
 *   / \
 *  4   5
 */
TreeNode root = new TreeNode(1);
root.left = new TreeNode(2);
root.right = new TreeNode(3);
root.left.left = new TreeNode(4);
root.left.right = new TreeNode(5);

这样,通过创建不同的TreeNode实例,并连接它们的leftright引用,可以构建出具体的二叉树结构。

前序遍历的过程

前序遍历的过程是递归的。假设我们有一个二叉树:

diff 复制代码
     1
    / \
   2   3
  / \
 4   5

前序遍历的顺序是:1 -> 2 -> 4 -> 5 -> 3

具体步骤如下:

  1. 访问根节点: 从根节点开始,首先访问根节点的值。

  2. 递归遍历左子树: 对根节点的左子树进行前序遍历,重复步骤1。

  3. 递归遍历右子树: 对根节点的右子树进行前序遍历,重复步骤1。

整个遍历的顺序是根节点 -> 左子树 -> 右子树。这个过程是递归的,因为对左子树和右子树的遍历过程本质上也是一个前序遍历。

前序遍历的代码实现

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class BinaryTreePreorderTraversal {

    public List<Integer> preorderTraversal(TreeNode root) {
        List<Integer> result = new ArrayList<>();
        preorder(root, result);
        return result;
    }

    private void preorder(TreeNode node, List<Integer> result) {
        if (node == null) {
            return;
        }

        // 1. 访问根节点
        result.add(node.val);

        // 2. 递归左子树
        preorder(node.left, result);

        // 3. 递归右子树
        preorder(node.right, result);
    }

    // 示例
    public static void main(String[] args) {
        /*
         * 示例二叉树:
         *      1
         *     / \
         *    2   3
         *   / \
         *  4   5
         */
        TreeNode root = new TreeNode(1);
        root.left = new TreeNode(2);
        root.right = new TreeNode(3);
        root.left.left = new TreeNode(4);
        root.left.right = new TreeNode(5);

        BinaryTreePreorderTraversal solution = new BinaryTreePreorderTraversal();
        List<Integer> result = solution.preorderTraversal(root);
        System.out.println(result);  // 输出: [1, 2, 4, 5, 3]
    }
}
相关推荐
岑梓铭12 分钟前
《考研408数据结构》第六章(5.1+5.2+5.3树、二叉树、线索二叉树)复习笔记
数据结构·笔记·考研·408·1024程序员节
苏纪云25 分钟前
数据结构<C++>——数组
java·数据结构·c++·数组·动态数组
周杰伦_Jay34 分钟前
【 RocketMQ 全解析】分布式消息队列的架构、消息转发与快速实践、事务消息
分布式·算法·架构·rocketmq·1024程序员节
sprintzer1 小时前
10.16-10.25力扣计数刷题
算法·leetcode
王哈哈^_^1 小时前
【数据集】【YOLO】【目标检测】建筑垃圾数据集 4256 张,YOLO建筑垃圾识别算法实战训推教程。
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·数据集
CoovallyAIHub1 小时前
不看异常,怎么学会识别异常?用“异常”指导异常检测!——NAGL方法解析(附代码地址)
深度学习·算法·计算机视觉
黄思搏2 小时前
2-3-4树 - 2-3-4 Tree 原理与 C# 实现
数据结构·1024程序员节
潼心1412o2 小时前
数据结构(长期更新)第3讲:顺序表相关操作
数据结构·1024程序员节
共享家95272 小时前
数据结构-并查集
数据结构·c++·算法
IT古董2 小时前
【第五章:计算机视觉-项目实战之推荐/广告系统】2.粗排算法-(2)理解粗排模型之离线部分:双塔模型结构精讲及实现
人工智能·算法·计算机视觉