当前位置: 首页 > article >正文

数据结构之二叉树遍历

二叉树的遍历

二叉树

先序遍历

先输入父节点,再遍历左子树和右子树:A、B、D、E、C、F、G

中序遍历

先遍历左子树,再输出父节点,再遍历右子树:D、B、E、A、F、C、G

后序遍历

先遍历左子树,再遍历右子树,最后输入父节点:D、E、B、F、G、C、A

核心理论

  • 根据父节点的输出顺序来确定先序、中序、后续。
  • 采用递归的方式对左子树和右子树进行遍历。
    • 每次递归都是一个方法的入栈操作,直至到最后一个子节点为空的时候,执行方法,然后方法栈弹出。
    • 每个方法栈弹出后,开始执行下一个方法栈,以此类推,相应的方法则可输出。

代码实现

package org.example.data.structure.basetree;

import java.util.ArrayList;
import java.util.List;
import java.util.Objects;

/**
 * @author xzy
 * @since 2024/9/16 15:14
 */
public class PersonNode {

    private static final List<Person> PRE_ORDER_LIST = new ArrayList<>();

    private static final List<Person> MID_ORDER_LIST = new ArrayList<>();

    private static final List<Person> POST_ORDER_LIST = new ArrayList<>();

    private Person data;

    private PersonNode left;

    private PersonNode right;

    public PersonNode() {
    }

    public PersonNode(Person person) {
        this.data = person;
    }

    public PersonNode(Person data, PersonNode left, PersonNode right) {
        this.data = data;
        this.left = left;
        this.right = right;
    }

    /**
     * 前序遍历
     */
    public List<Person> preOrder() {
        PRE_ORDER_LIST.add(this.getData());
        if (Objects.nonNull(this.getLeft())) {
            this.getLeft().preOrder();
        }
        if (Objects.nonNull(this.getRight())) {
            this.getRight().preOrder();
        }
        return PRE_ORDER_LIST;
    }

    /**
     * 中序遍历
     */
    public List<Person> midOrder() {
        if (Objects.nonNull(this.getLeft())) {
            this.getLeft().midOrder();
        }
        MID_ORDER_LIST.add(this.getData());
        if (Objects.nonNull(this.getRight())) {
            this.getRight().midOrder();
        }
        return MID_ORDER_LIST;
    }

    /**
     * 后续遍历
     */
    public List<Person> postOrder() {
        if (Objects.nonNull(this.getLeft())) {
            this.getLeft().postOrder();
        }
        if (Objects.nonNull(this.getRight())) {
            this.getRight().postOrder();
        }
        POST_ORDER_LIST.add(this.getData());
        return POST_ORDER_LIST;
    }

    public Person getData() {
        return data;
    }

    public void setData(Person data) {
        this.data = data;
    }

    public PersonNode getLeft() {
        return left;
    }

    public void setLeft(PersonNode left) {
        this.left = left;
    }

    public PersonNode getRight() {
        return right;
    }

    public void setRight(PersonNode right) {
        this.right = right;
    }
}

源码与测试案例

gitee地址


http://www.kler.cn/news/316066.html

相关文章:

  • 【Linux系统编程】第二十一弹---进程的地址空间
  • 《概率论与数理统计》学渣笔记
  • uni-app功能 1. 实现点击置顶,滚动吸顶2.swiper一个轮播显示一个半内容且实现无缝滚动3.穿透修改uni-ui的样式
  • 美团测开OC!
  • 【论文串烧】多媒体推荐中的模态平衡学习 | 音视频语音识别中丢失导致的模态偏差对丢失视频帧鲁棒性的影响
  • erlang学习:Linux常用命令2
  • Github 2024-09-23 开源项目周报 Top15
  • Kubernetes集群架构、安装和配置全面指南
  • 目标检测-数据集
  • 【MySQL】获取最近7天和最近14天的订单数量,使用MySQL详细写出,使用不同的方法
  • 想学习下Python和深度学习,Python需要学习到什么程度呢?
  • C++入门——(类的默认成员函数)析构函数
  • 数据库基础知识---------------------------(3)
  • 早期病毒和反病毒技术(网络安全小知识)
  • MATLAB系列08:输入/输入函数
  • SSCMS 插件示例 一插件创建及插件菜单
  • 大厂面试真题:SpringBoot的核心注解
  • FastAPI 的隐藏宝石:自动生成 TypeScript 客户端
  • Golang | Leetcode Golang题解之第423题从英文中重建数字
  • C++学习
  • 机器学习——Bagging
  • String类和String类常用方法
  • LinuxC高级作业1
  • css边框修饰
  • 代码随想录:打家劫舍||
  • 鸿蒙OpenHarmony【轻量系统内核扩展组件(CPU占用率)】子系统开发
  • 【C++】面向对象编程的三大特性:深入解析继承机制
  • Open3D(C++) 基于点云的曲率提取特征点(自定义阈值法)
  • Unity DOTS系列之IJobChunk来迭代处理数据
  • 速盾:高防cdn防御的时候会封ip吗?