深入理解树的遍历:前序遍历、中序遍历、后序遍历及层次遍历

引言

树(Tree)是一种常见的非线性数据结构,用于模拟具有层次关系的数据。树的遍历是树的基本操作之一,用于按一定顺序访问树中的所有节点。本文将详细介绍树的四种遍历方式:前序遍历、中序遍历、后序遍历及层次遍历。

树的遍历

树的遍历是指按照某种规则访问树中的每个节点,并且每个节点仅访问一次。树的遍历方式主要有四种:前序遍历、中序遍历、后序遍历和层次遍历。

前序遍历(Pre-order Traversal)

前序遍历的顺序是:先访问根节点,再访问左子树,最后访问右子树。其递归实现如下:

class BinaryTree {TreeNode root;BinaryTree() {root = null;}// 前序遍历void preOrder(TreeNode node) {if (node == null) return;System.out.print(node.value + " ");preOrder(node.left);preOrder(node.right);}// 测试前序遍历public static void main(String[] args) {BinaryTree tree = new BinaryTree();tree.root = new TreeNode(1);tree.root.left = new TreeNode(2);tree.root.right = new TreeNode(3);tree.root.left.left = new TreeNode(4);tree.root.left.right = new TreeNode(5);System.out.print("前序遍历结果: ");tree.preOrder(tree.root);  // 输出:1 2 4 5 3}
}
1
2
3
4
5
访问顺序:1 -> 2 -> 4 -> 5 -> 3

中序遍历(In-order Traversal)

中序遍历的顺序是:先访问左子树,再访问根节点,最后访问右子树。其递归实现如下:

class BinaryTree {TreeNode root;BinaryTree() {root = null;}// 中序遍历void inOrder(TreeNode node) {if (node == null) return;inOrder(node.left);System.out.print(node.value + " ");inOrder(node.right);}// 测试中序遍历public static void main(String[] args) {BinaryTree tree = new BinaryTree();tree.root = new TreeNode(1);tree.root.left = new TreeNode(2);tree.root.right = new TreeNode(3);tree.root.left.left = new TreeNode(4);tree.root.left.right = new TreeNode(5);System.out.print("中序遍历结果: ");tree.inOrder(tree.root);  // 输出:4 2 5 1 3}
}
1
2
3
4
5
访问顺序:4 -> 2 -> 5 -> 1 -> 3

后序遍历(Post-order Traversal)

后序遍历的顺序是:先访问左子树,再访问右子树,最后访问根节点。其递归实现如下:

class BinaryTree {TreeNode root;BinaryTree() {root = null;}// 后序遍历void postOrder(TreeNode node) {if (node == null) return;postOrder(node.left);postOrder(node.right);System.out.print(node.value + " ");}// 测试后序遍历public static void main(String[] args) {BinaryTree tree = new BinaryTree();tree.root = new TreeNode(1);tree.root.left = new TreeNode(2);tree.root.right = new TreeNode(3);tree.root.left.left = new TreeNode(4);tree.root.left.right = new TreeNode(5);System.out.print("后序遍历结果: ");tree.postOrder(tree.root);  // 输出:4 5 2 3 1}
}
1
2
3
4
5
访问顺序:4 -> 5 -> 2 -> 3 -> 1

层次遍历(Level-order Traversal)

层次遍历的顺序是:从根节点开始,按层次从上到下、从左到右依次访问每个节点。其实现如下:

import java.util.LinkedList;
import java.util.Queue;class BinaryTree {TreeNode root;BinaryTree() {root = null;}// 层次遍历void levelOrder(TreeNode node) {if (node == null) return;Queue<TreeNode> queue = new LinkedList<>();queue.add(node);while (!queue.isEmpty()) {TreeNode tempNode = queue.poll();System.out.print(tempNode.value + " ");if (tempNode.left != null) queue.add(tempNode.left);if (tempNode.right != null) queue.add(tempNode.right);}}// 测试层次遍历public static void main(String[] args) {BinaryTree tree = new BinaryTree();tree.root = new TreeNode(1);tree.root.left = new TreeNode(2);tree.root.right = new TreeNode(3);tree.root.left.left = new TreeNode(4);tree.root.left.right = new TreeNode(5);System.out.print("层次遍历结果: ");tree.levelOrder(tree.root);  // 输出:1 2 3 4 5}
}
1
2
3
4
5
访问顺序:1 -> 2 -> 3 -> 4 -> 5

结论

通过上述讲解和实例代码,我们详细展示了树的四种遍历方式:前序遍历、中序遍历、后序遍历及层次遍历。每种遍历方式有其特定的应用场景和特点。希望这篇博客对您有所帮助!记得关注、点赞和收藏哦,以便随时查阅更多优质内容!


如果您觉得这篇文章对您有帮助,请关注我的CSDN博客,点赞并收藏这篇文章,您的支持是我持续创作的动力!


关键内容总结

  • 前序遍历:根节点 -> 左子树 -> 右子树
  • 中序遍历:左子树 -> 根节点 -> 右子树
  • 后序遍历:左子树 -> 右子树 -> 根节点
  • 层次遍历:按层次从上到下、从左到右依次访问每个节点
  • Java代码实例展示如何实现四种遍历方式

推荐阅读:深入探索设计模式专栏,详细讲解各种设计模式的应用和优化。点击查看:深入探索设计模式。


特别推荐:设计模式实战专栏,深入解析设计模式的实际应用,提升您的编程技巧。点击查看:设计模式实战。

如有任何疑问或建议,欢迎在评论区留言讨论。谢谢阅读!

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

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

相关文章

C语言程序设计10

程序设计10 问题10_1代码10_1结果10_1 问题10_2代码10_2结果10_2 问题10_3代码10_3结果10_3 问题10_1 下列给定程序中已建立一个带结点的单向链表&#xff0c;链表中的各结点数据中的数据递增有序链接&#xff0c;函数 f u n fun fun 的功能是&#xff1a;把形参 x x x 的值放…

【echarts】存在左右Y轴,多个图例切换时,图宽度会缩短(没有右轴,图宽度正常。 高亮右轴,图宽度会变窄。)- 已解决

问题描述&#xff1a; 在绘制图表时&#xff0c;左侧 Y 轴有一条曲线&#xff0c;右侧 Y 轴有三条曲线。初始化时发现&#xff0c;图表的宽度变窄了&#xff0c;这在 PC 端不太明显&#xff0c;但在移动端特别明显。 没有右轴&#xff0c;图宽度正常。 高亮右轴&#xff0c;图…

Windows系统设置暂停更新,暂停时间可达3000天,“永久”暂停更新,亲测有效

好多小伙伴被Windows系统的更新搞得很烦&#xff0c;经常在使用中自己下载更新包&#xff0c;占用网路资源&#xff0c;过段时间就要更新&#xff0c;特别讨厌 今天教你一招&#xff0c;可以暂停更新长达3000天&#xff0c;亲测有效 1、打开系统CMD命令执行窗口&#xff0c;输…

英伟达、Mistral AI 开源企业级大模型,120亿参数、可商用

全球AI领导者英伟达&#xff08;Nvidia&#xff09;和著名开源大模型平台Mistral.ai联合开源了&#xff0c;企业级大模型Mistral NeMo 12B。&#xff08;以下简称“MN 12B”&#xff09; 据悉&#xff0c;MN 12B一共有基础和指令微调两种模型&#xff0c;支持128K上下文长度&a…

因为很会用工具,拿下了很多客户!

作为一名想要得到更多业绩的打工人&#xff0c;能提高工作效率的工具一定要拥有&#xff01; 今天&#xff0c;就给大家分享一个职场必备的提效神器&#xff0c;一起来看看它都有哪些功能吧&#xff01; 1、多渠道客源 它可以从多个渠道去获取你想要的客户资源&#xff0c;无…

代码随想录——一和零(Leetcode474)

题目链接 0-1背包 class Solution {public int findMaxForm(String[] strs, int m, int n) {// 本题m&#xff0c;n为背包两个维度// dp[i][j]:最多右i个0和j个1的strs的最大子集大小int[][] dp new int[m 1][n 1];// 遍历strs中字符串for(String str : strs){int num0 …

题解|2024暑期牛客多校03

【原文链接】 比赛链接&#xff1a;2024牛客暑期多校训练营3 A.Bridging the Gap 2 题目大意 n n n个人过河&#xff0c;第 i i i 个人初始有 h i h_i hi​ 点体力。 由于船的限制&#xff0c;每次过河&#xff08;或返回&#xff09;至少需要乘坐 l l l 人&#xff08;来…

SELECT语句

SELECT语句 前言&#xff1a; 在我们MySQL中&#xff0c;数据的存储是类似于EXCEL的&#xff0c;是以表格的形式存在的&#xff0c;所以都是一行一行的数据或者是一个一个的数据。 我们可以非常形象的理解一下&#xff0c;每一**列&#xff08;column&#xff09;都是一个对象…

免费【2024】springboot 必录德健身器材用品网的设计与实现

博主介绍&#xff1a;✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围&#xff1a;SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…

使用 Docker 快速入门 RabbitMQ:安装与基本操作

引言 RabbitMQ 是一个流行的开源消息代理软件&#xff0c;它支持多种消息协议&#xff0c;并且易于部署和使用。Docker 作为一个轻量级容器化平台&#xff0c;可以简化 RabbitMQ 的安装和部署过程。本文将引导你通过 Docker 快速安装 RabbitMQ&#xff0c;并进行一些基本操作。…

在 `JDK 17` 中使用反射

在 JDK 17 中使用反射的基本步骤如下&#xff1a; 步骤一&#xff1a;导入相关类 import java.lang.reflect.Field; import java.lang.reflect.Method; import java.lang.reflect.Constructor;步骤二&#xff1a;获取类对象 // 通过类的全限定名获取 Class 对象 Class<?&…

性能对比:Memcached 与 Redis 的关键差异

性能对比&#xff1a;Memcached 与 Redis 的关键差异 在选择合适的缓存系统时&#xff0c;Memcached 和 Redis 是最常被提及的两种技术。它们都是内存存储系统&#xff0c;用于提高数据访问速度和应用性能。尽管它们在功能上有很多相似之处&#xff0c;但在性能、特性和应用场…

java面向对象进阶进阶篇--《包和final》

一、前言 今天还是面向对象相关知识点的分享&#xff0c;包是写小型项目时不可或缺的存在&#xff0c;final关键字用的地方不算太多。idea会提示我们导包&#xff0c;有时会自动导包&#xff0c;确实十分方便。但是我们也不能不会自己去导包。 面向对象篇不出意外的话本周就要…

22集 如何minimax密钥和groupid-《MCU嵌入式AI开发笔记》

22集 如何获取minimax密钥和groupid-《MCU嵌入式AI开发笔记》 minimax密钥获取 https://www.minimaxi.com/platform 进入minimax网站&#xff0c;注册登录后&#xff0c;进入“账户管理”&#xff0c; 然后再点击“接口密钥”&#xff0c;然后再点击“创建新的密钥”。 之…

如何使用aiohttp或requests-async等库并发地执行多个HTTP请求

在Python中&#xff0c;要并发地执行多个HTTP请求&#xff0c;可以使用aiohttp这样的异步HTTP客户端库&#xff0c;因为它支持异步编程&#xff0c;能够显著提高IO密集型任务的性能&#xff0c;比如网络请求。requests-async并不是一个广泛认知的库&#xff08;虽然可能存在类似…

《0基础》学习Python——第十九讲__爬虫/<2>

一、用get请求爬取一般网页 首先由上节课我们可以找到URL、请求方式、User-Agent以及content-type 即&#xff1a;在所在浏览器页面按下F12键&#xff0c;之后点击网路-刷新&#xff0c;找到第一条双击打开标头即可查看上述所有内容&#xff0c;将上述URL、User-Agent所对应的…

1.6、计算机系结构

Flynn分类法 Flynn分类法是1966年&#xff0c;M. J. Flynn提出的根据指令流、数据流的多倍性特征对计算机系统的分类方法。 指令流为机器执行的指令序列。数据流是由指令调用的数据序列。包括输入数据和中间结果&#xff0c;不包括输出数据 分类 Flynn把计算机系统的结构分…

初学MWA(Modern Web App)那些事-3-做一个简单的计算器

初学MWA(Modern Web App&#xff09;那些事-3-做一个简单的计算器 目录 初学MWA(Modern Web App&#xff09;那些事-3-做一个简单的计算器前言一、本节学习目标二、计算器实例项目创建过程2.1 创建一个HTML文档2.2 查看新建的html文档2.3 Web应用开发&#xff1a;初始化设置2.4…

linux C++ onnxruntime yolov8 视频检测Demo

linux C onnxruntime yolov8 视频检测Demo 目录 项目目录 效果 ​编辑CMakeLists.txt 代码 下载 项目目录 效果 ./yolov8_demo --help ./yolov8_demo -c2 -ptrue ./yolov8_demo -c1 -strue CMakeLists.txt # cmake needs this line cmake_minimum_required(VERSION 3…

AMD EPYC处理器性能宣称远超Nvidia Grace CPU

AMD近期发布了一份博客文章&#xff0c;其中对比了其EPYC处理器与Nvidia Grace Hopper Superchip&#xff08;基于Arm架构的72核CPU&#xff09;在一系列基准测试中的性能&#xff0c;声称EPYC处理器在多种工作负载下的表现最多可高出两倍。这一比较突显了AMD在数据中心CPU市场…