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

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

提供二叉树的根节点 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]
    }
}
相关推荐
Sam_Deep_Thinking3 小时前
学数据结构到底有什么用
数据结构
kobesdu3 小时前
人形机器人SLAM:技术挑战、算法综述与开源方案
算法·机器人·人形机器人
椰羊~王小美5 小时前
随机数概念及算法
算法
阿Y加油吧5 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
不要秃头的小孩5 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
We་ct6 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣6 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
hipolymers7 小时前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
CS创新实验室7 小时前
从“跑得动”到“跑得稳”:深度剖析数据结构究竟是理论点缀还是核心战力?
数据结构