二叉树的前序/中序/后序遍历新手入门介绍

news2025/8/2 23:58:06

一、前序遍历 | 根左右(DLR)

1.1 简介

前序遍历简介也叫先序遍历
前序遍历 可以分为三部分:根、左子树、右子树
先遍历根节点 、再遍历左子树、再遍历右子树
左/右 子树遍历方法:先访问根节点,再访问 左孩子节点,访问到左孩子节点之后判断该左孩子节点是否是 叶子节点(叶子节点 也就是说 这个节点下没有任何节点,形容的还是很贴切的,因为一棵树的最末端的部分就是叶子) 如果不是叶子节点,继续按照 根左右 的访问顺序继续访问,当访问到该左孩子是叶子节点 时,再访问 右孩子 节点,同理 也按照 根左右 的顺序进行访问 右孩子节点,同理和左孩子一样 判断该节点是否是 叶子节点,不是叶子节点 继续 按照 根左右 的遍历顺序进行访问,直到访问到整棵树的 最后一个 叶子节点的 右孩子 表示 该左子树/右子树遍历结束

1.2 示例

在这里插入图片描述
例如上图:
左子树:
在这里插入图片描述

1.2.1

访问 根节点 1 ,节点 1 为 根节点 因此 先访问 节点 1,且接下俩访问 节点 1 的左孩子

1.2.2

访问 节点 2,节点 2 为 节点1 的左孩子,且 节点 2 为根节点,因此 现在 访问 节点 2,接下来继续访问 节点 2 的左孩子

1.2.3

访问 节点 4,节点 4 为 节点 2 的左孩子,且 节点 4 为根节点,因此 现在遍历 节点 4,且接下来 继续访问 节点 4 的左孩子

1.2.4

访问 节点 5 ,节点 4 没有左孩子与右孩子,因此 节点 4 为叶子节点,表示 根节点 2 的 左子树已经遍历结束,因此访问 节点 2 的 右孩子 节点 5,且 节点 5 为非叶子节点,接下来 继续访问 节点 5 的 左孩子

1.2.5

访问 节点 7 ,节点 7 为 节点 5 的左孩子,且节点 7 为非叶子节点,接下来 继续访问 节点 7 的左孩子节点

1.2.6

访问 节点 9 ,根节点 7 没有左孩子 因此访问 节点 7 的右孩子 节点 9 ,且节点 9 为叶子节点,因此表示 根节点 1 的 左子树 已经全部遍历结束,接下来 遍历 根节点 1 的右子树

右子树:
在这里插入图片描述

1.2.7

访问 节点 3 ,遍历右子树 先访问 根节点 1 的 右孩子 节点 3,节点 3 为非叶子节点 继续 访问 左孩子,节点 3 没有 左孩子 因此 访问 节点 3

1.2.8

访问 节点 6,节点 3 为非叶子节点,因此访问 该节点的 左孩子,由于没有左孩子 ,因此 访问右孩子 节点 6,节点 6 为非叶子节点,且为根节点,继续访问 节点 6 的 左孩子节点

1.2.9

访问 节点 8 ,节点 6 没有左孩子,因此访问 节点 6 的右孩子 节点 8,且节点 8 为叶子节点,表示整棵树的遍历结束

前序遍历 顺序为: 1 -> 2 -> 4 -> 5 -> 7 -> 9 -> 3 -> 6 -> 8

前序遍历基本性质:

  1. 遍历顺序为 先根再左再右
  2. 遍历结束标志,遍历右子树的最后一个子树的右孩子为叶子节点,或右孩子节点为空(即不存在)则表示遍历结束
  3. 最先遍历根节点,遍历顺序的第一个即 为整棵树的根节点

二、中序遍历 | 左根右(LDR)

2.1 简介

前序遍历 可以分为三部分:左子树、根、右子树
先遍历左子树 、再遍历根节点、再遍历右子树

中序遍历顺序:先访问该树的左子树 , 再访问该树的根节点,最后访问该树的右子树
中序遍历方法:先访问一棵树的左孩子节点,若该节点为非叶子节点,继续访问该节点的左孩子,直到遍历到叶子节点或左孩子节点不存在时,访问右孩子节点,同理并判断该右孩子节点是否是叶子节点或是否存在,若存在且为非叶子节点,那么将继续按照 左根右 访问顺序 遍历,最后遇到叶子节点或 右孩子节点不存在时,访问根节点。

2.2 示例

在这里插入图片描述

2.2.1

访问 节点 4,首先访问根节点 1 的 左孩子节点 2 ,节点2 为非叶子节点,则继续访问 节点 2 的 左孩子 节点 4 ,节点 4 为 非叶子节点 因此 继续访问 节点 4 的 左孩子 ,节点 4 没有 左孩子 ,因此 接下来 访问 根节点 4 ,因此 节点 4 为第一个访问的 节点,接下来 继续按照 左根右 的顺序 遍历 节点 4 的右孩子 节点。

2.2.2

访问 节点 7,按照 左根右 的 遍历顺序 ,遍历 右孩子:节点 7

2.2.3

访问 节点 2 , 节点 7 为叶子节点,则表示
在这里插入图片描述
这一棵子树已经全部遍历结束了,也表示 节点 2 的左子树已经遍历完了 ,因此按照 左根右 的遍历顺序,现在访问 根节点 2

2.2.4

访问 节点 5,访问完 节点 2 之后开始 访问 右孩子 节点 5

2.2.5

访问 根节点 1,节点 5 为叶子节点,因此 表示 根节点 1 的左子树已经全部访问完成,因此 按照 左根右 的遍历顺序,现在 访问根节点 1

2.2.6

访问 节点 3 , 左子树和根节点已经全部访问完成,接下来开始访问 右子树,右子树 第一个为 节点3 的 左孩子节点,由于 节点 3 没有 左孩子,因此现在 访问 根节点 3

2.2.7

访问 节点 6,根节点 3 访问之后 开始访问 右孩子节点 ,即 节点 6,且 节点 6 为叶子节点,因此表示 整个遍历 结束。

中序遍历 顺序为: 4 -> 7 -> 2 -> 5 -> 1 -> 3 -> 6

中序遍历基本性质:

  1. 遍历顺序为 先左子树再根节点最后右子树
  2. 根据根节点可以把中序遍历的顺序划分为 左子树与右子树

三、后序遍历 | 左右根(LRD)

3.1 简介

熟悉过以上两种之后,应该也熟悉了这个套路
无非还是分为以下三大部分
左子树、右子树、根
后序遍历为 左右根 ,因此 遍历的大致顺序为:
先遍历左子树、再遍历右子树、最后遍历 根节点

后序遍历:和前序中序其实都一样,按照 对应顺序访问,如果不是叶子节点就一直 按照遍历的顺序继续访问下去,直到左子树遍历结束,接下来按照同样的方法遍历右子树,右子树遍历结束之后,遍历根节点 因此,整棵树的根节点是 最后一个访问的与前序遍历 恰好相反前序遍历第一个访问的是根节点

3.2 示例

在这里插入图片描述
先遍历 根节点 1 的 左子树
在这里插入图片描述

3.2.1

访问节点 4 , 按照左右根 访问顺序,首先访问 根节点 1 的左孩子 节点 2,节点 2 为非叶子节点,继续访问 节点 2 的左孩子节点 4,节点 4 为叶子节点,因此遍历的第一个节点为 节点 4.

3.2.2

访问节点 8,节点 2 的左孩子节点已经访问结束,接下来 继续访问 节点 2 的右孩子 节点 5 节点 5 为非叶子节点 因此继续访问 节点 5 的 左孩子 节点 8,且节点 8 为叶子节点

3.2.3

**访问节点 5 **,因为 节点 8 为叶子节点 因此 节点 5 的左子树已经全部访问完成,接下来 按照 左右根的顺序,继续访问节点 5 的右孩子,因为 节点 5 没有右孩子,因此现在访问 根节点 5

3.2.4

访问节点 2 , 节点 5 访问完之后,表示 节点 2 的左右子树已经全部访问完毕,因此按照 左右根,现在 访问 根节点 2

节点 1 的左子树已经全部遍历结束,因此接下里开始遍历,右子树
在这里插入图片描述

3.2.5

访问节点 9,首先访问 节点 3 节点 3 为 非叶子节点,因此继续 访问 节点 3 的左孩子 节点 6,节点 6 同样为 非叶子节点,因此继续访问 节点 6 的左孩子,节点 6 没有左孩子,因此 访问 节点 6 的右孩子节点 9,且节点 9 为叶子节点

3.2.6

访问节点 6,节点 9 为叶子节点,表示 根节点 6 的 左右子树已经全部遍历结束,因此按照 左右根的 顺序,接下来 访问根节点 6.

3.2.7

访问节点 7,节点 6 遍历完之后表示 节点 3 的左子树已经全部遍历结束,接下来开始遍历 节点 3 的右子树 中的 节点 7,且 节点 7 为叶子节点,因此 节点 3 的右子树也全部遍历结束

3.2.8

访问节点 3,节点 3 的左右子树已经全部遍历结束,按照 左右根 的遍历顺序,因此 现在访问 根节点 3,也表示 根节点 1 的左右子树 也已经全部 访问结束,接下俩 访问 根节点 1

遍历根节点

3.2.9

访问根节点 1,根节点 1 的左右子树全部遍历结束之后,最后遍历整棵树的根节点 1,也表示整棵树遍历结束。
后序遍历 顺序为:4 -> 8 -> 5 -> 2 -> 9 -> 6 -> 7 -> 3 -> 1

后序遍历基本性质:

  1. 后序遍历顺序为 先左子树再右子树最后根节点
  2. 后序遍历顺序中的最后一个节点为根节点

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/34952.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

04、SpringAOP详解

1、Spring AOP简介 1、什么是AOP 1、定义阐述 AOP的全称是 Aspect Oriented Programming,是面向切面编程的技术,把一个个的横切关注点放到某个模块中去,称之为切面。那么每一个的切面都能影响业务的某一种功能,切面的目的就是功…

蒙泰转债上市价格预测

蒙泰转债基本信息转债名称:蒙泰转债,评级:A,发行规模:3.0亿元。正股名称:蒙泰高新,今日收盘价:31.3,转股价格:26.15。当前转股价值 转债面值 / 转股价格 * 正…

【Java进阶】学好常用类,code省时省力

一、工具类 所谓工具类,即将完成通用功能的方法分类放到类中,工具类能够被高效地重复使用,使我们的编码快速、高效。 工具类的设计 工具方法使用public static修饰,通过工具类名调用工具方法。对于工具类,我们通常都…

AI内容生成时代:该如何和AI对话?

北大出版社,人工智能原理与实践 人工智能和数据科学从入门到精通 详解机器学习深度学习算法原理 人工智能原理与实践 全面涵盖人工智能和数据科学各个重要体系经典 AI自动生成内容(AIGC)最近可以说非常热门。而如何给AI有效输入提示,从而达…

基于JSP的保险业务管理系统【数据库设计、源码、开题报告】

数据库脚本下载地址: https://download.csdn.net/download/itrjxxs_com/86467452 主要使用技术 SpringStruts2HibernateJSPJSCSSMysql 功能介绍 本系统旨在为当今的保险行业提供一套综合性的管理系统业务,系统的主要用户为保险的购买者以及系统的管理…

安信可Ai-WB1系列固件烧录指导

文章目录前言1 准备材料2 硬件连接3 烧录软件的使用联系我们前言 本文主要介绍如何使用Ai-WB1系列模组以及开发板更新固件烧录操作说明。 1 准备材料 AI-WB1系列模组或者开发板USB转TTL模块/Type-C数据线固件详见链接常见固件中的出厂固件串口工具链接烧录工具详见链接 烧录…

在github上部署静态页面

使用github-page部署静态页面 需求 假如你辛辛苦苦写好了一个静态网页,很想要炫耀一下,让大家都可以通过公网访问看到我的网页。但是不想太麻烦,买服务器,安装软件,部署环境,配置域名,备案&…

navicate的安装使用

1 navicat概述 Navicat for MySQL 是管理和开发 MySQL 或 MariaDB 的理想解决方案。这套全面的前端工具为数据库管理、开发和维护提供了一款直观而强大的图形界面。官网: http://www.navicat.com.cn 2 navicat安装 网上有教程 3 navicat使用 3.1 建立和mysql服务…

金融行业数据安全法律法规清单

近年来,随着业务快速发展,金融机构积累了大量的数据,其中包含大量的客户信息等敏感数据,数据信息一旦泄露,不仅会给客户造成直接经济损失,也会给金融业的声誉带来负面影 响,甚至会导致金融机构承…

dreamweaver作业静态HTML网页设计 大学美食菜谱网页制作教程(web前端网页制作课作业)

🎀 精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

Linux之权限【读、写、执行】【详细总结】

目录权限相关介绍rwx权限详解rwx作用到文件rwx作用到目录文件及目录权限实际案例权限修改第一种方式,,-,变更权限案例演示:第二种方式:通过数字变更权限chmod urwx,grx,ox 文件目录名 chmod 751 文件目录名修改文件所…

工时管理:警惕员工时间偷窃!企业应该如何避免?

员工时间偷窃是指员工捏造工时,对工时进行四舍五入,或故意延长休息时间,从事与工作无关的活动,却谎报了工作时间,接受了公司在这期间支付的劳动报酬。大家都知道的“带薪摸鱼”这个词,就是员工时间偷窃的一…

Redis学习

Redis1.NoSQL数据库概述NoSQL使用场景NoSQL不适用场景2.Redis2.1应用场景2.1.1 配合关系型数据库做高速缓存2.1.2 多样的数据结构存储持久化数据2.1.3 Redis内存管理2.1.3.1 删除策略2.1.4 Redis持久化机制2.1.4.1 什么是RDB持久化?2.1.4.2 RDB创建快照时会阻塞主线…

小啊呜产品读书笔记001:《邱岳的产品手记-12》第22讲 产品经理的图文基本功(上):产品文档 23讲产品经理的图文基本功(下):产品图例

小啊呜产品读书笔记001:《邱岳的产品手记-12》第22讲 产品经理的图文基本功(上):产品文档 & 23讲产品经理的图文基本功(下):产品图例一、今日阅读计划二、泛读&知识摘录1、第22讲 产品经…

WPF中使用MVVM模型进行数据绑定

文章目录前言一、声明一个类用来实现接口 INotifyPropertyChanged二、实例化ViewModel对象1.新建MainViewModel模型类2.实例化对象三、在界面设计代码中进行绑定四、应用前言 WPF数据绑定对于WPF应用程序来说尤为重要,本文将讲述使用MVVM模式进行数据绑定的四步走用…

如何实现一个优秀的 HashTable 散列表?

本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问。 前言 大家好,我是小彭。 在前几篇文章里,我们聊到了 Java 中的几种线性表结构,包括 ArrayList、LinkedList、ArrayDeque 等。今天&#xf…

ArcGIS绘制地球

下面这个图是非常不错的,截取自论文的一张图: 学了十几年地理学,最初的兴趣恐怕还是小时候常常摆弄的地球仪;现在终于有机会尝试地球仪风格制作了。 虽然迟到了十几年,不过今天还是有机会“复现”小时候的地球仪。 先…

使用docker-compose部署达梦DEM管理工具,mac m1系列适用

之前搭建了mac m1下基于docker的达梦库(地址),但是没有一个好用的管理端。 用过DBeaver,可以使用自定jar创建dm链接,只做简单查询还行,要是用到一些修改、大文本查看、配置修改等高级点的功能就不行了。 …

Redis-使用java代码操作Redis

目录 Java连接Redis Java链接 测试是否连接 Java操作Redis Redis字符串(String) Redis哈希(Hash) Redis列表&#xff08;List&#xff09; Redis集合&#xff08;Set&#xff09; Java连接Redis 前置条件&#xff1a;Redis的服务要开启 pom依赖 <dependency>&l…

小熊U租港交所上市:市值28亿港元 京东联想腾讯是股东

雷递网 雷建平 11月24日小熊U租母公司凌雄科技集团有限公司&#xff08;简称&#xff1a;“凌雄科技”&#xff0c;股票代码为&#xff1a;“02436”&#xff09;今日在港交所上市。凌雄科技发行价为7.6港元&#xff0c;募资总额为3.37亿港元。凌雄科技开盘价为7.9港元&#xf…