Java二叉树的前中后序遍历
创始人
2025-05-30 13:19:58
0

Java二叉树的前中后序遍历

  • 1.前序遍历
    • 1.1前序遍历概念
    • 1.2前序遍历习题
  • 2.中序遍历
    • 2.1中序遍历概念
    • 2.2中序遍历习题
  • 3.后续遍历
    • 3.1后序遍历概念
    • 3.2后序遍历习题

大家好,我是晓星航。今天为大家带来的是 Java二叉树的前中后序遍历 的讲解!😀

1.前序遍历

1.1前序遍历概念

[前序遍历](前序遍历_百度百科 (baidu.com))(VLR), [1] 是二叉树遍历的一种,也叫做先根遍历、先序遍历、前序周游,可记做根左右。前序遍历首先访问根结点然后遍历左子树,最后遍历右子树。

数学表达式形式:当对一棵数学表达式树进行中序,前序和后序遍历时,就分别得到表达式的中缀、前缀和后缀形式。

在后缀(postfix)表达式中,每个操作符跟在操作数之后,操作数按从左到右的顺序出现。在前缀(prefix)表达式中,操作符位于操作数之前。在前缀和后缀表达式中不会存在歧义。

因此,在前缀和后缀表达式中都不必采用括号或优先级。从左到右或从右到左扫描表达式并采用操作数栈,可以很容易确定操作数和操作符的关系。若在扫描中遇到一个操作数,把它压入堆栈,若遇到一个操作符,则将其与栈顶的操作数相匹配。把这些操作数推出栈,由操作符执行相应的计算,并将所得结果作为操作数压入堆栈。

1.2前序遍历习题

二叉树的前序遍历。 OJ链接

解法一(遍历思路:只new一个list,然后直接递归走完每一次,直接返回list):

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {List list = new ArrayList<>();public List preorderTraversal(TreeNode root) {if (root == null) {return list;}list.add(root.val);preorderTraversal(root.left);preorderTraversal(root.right);return list;}
}

解法二(子问题思路:每次都new一个新的list 再每一次递归时将他们直接存入list中):

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public List preorderTraversal(TreeNode root) {List list = new ArrayList<>();if (root == null) {return list;}list.add(root.val);List leftTree = preorderTraversal(root.left);list.addAll(leftTree);List rightTree = preorderTraversal(root.right);list.addAll(rightTree);return list;}
}

思路:利用循环递归的方法来解决前序遍历法。

2.中序遍历

2.1中序遍历概念

[中序遍历](中序遍历_百度百科 (baidu.com))是二叉树遍历的一种,也叫做中根遍历、中序周游。在二叉树中,中序遍历首先遍历左子树,然后访问根结点,最后遍历右子树。

数学表达式形式:当对一棵数学表达式树进行中序,前序和后序遍历时,就分别得到表达式的中缀、前缀和后缀形式。中缀(infix)形式即平时所书写的数学表达式形式,在这种形式中,每个二元操作符(也就是有两个操作数的操作符)出现在左操作数之后,右操作数之前。在使用中缀形式时,可能会产生一些歧义。例如,x+y ×z可以理解为(x+y) ×z或x+ (y ×z)。为了避免这种歧义,可对操作符赋于优先级并采用优先级规则来分析中缀表达式。在完全括号化的中缀表达式中,每个操作符和相应的操作数都用一对括号括起来。更甚者把操作符的每个操作数也都用一对括号括起来。如( (x) + (y) ),( (x) + ( (y) * (z) ) )和( ( (x) + (y) ) * ( (y) + (z) ) ) * (w)。

2.2中序遍历习题

二叉树中序遍历 。OJ链接

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public List inorderTraversal(TreeNode root) {List list = new ArrayList<>();if (root == null) {return list;}List leftTree = inorderTraversal(root.left);list.addAll(leftTree);list.add(root.val);List rightTree = inorderTraversal(root.right);list.addAll(rightTree);return list;}
}

思路:子问题思路:每次都new一个新的list 再每一次递归时将他们直接存入list中,利用循环递归的方法来解决前序遍历法。

3.后续遍历

3.1后序遍历概念

后序遍历(LRD)是二叉树遍历的一种,也叫做后根遍历、后序周游,可记做左右根。后序遍历有递归算法和非递归算法两种。在二叉树中,先左后右再根,即首先遍历左子树,然后遍历右子树,最后访问根结点。

3.2后序遍历习题

二叉树的后序遍历 。OJ链接

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public List postorderTraversal(TreeNode root) {List list = new ArrayList<>();if (root == null) {return list;}List leftTree = postorderTraversal(root.left);list.addAll(leftTree);List rightTree = postorderTraversal(root.right);list.addAll(rightTree);list.add(root.val);return list;}
}

思路:子问题思路:每次都new一个新的list 再每一次递归时将他们直接存入list中,利用循环递归的方法来解决前序遍历法。

感谢各位读者的阅读,本文章有任何错误都可以在评论区发表你们的意见,我会对文章进行改正的。如果本文章对你有帮助请动一动你们敏捷的小手点一点赞,你的每一次鼓励都是作者创作的动力哦!😘

相关内容

热门资讯

安卓系统开后门怎么开,操作步骤... 你有没有想过,你的安卓手机里可能藏着一个秘密通道,一个可以让你轻松掌控手机的小技巧?没错,我要说的就...
京东和安卓系统哪个好用,谁更胜... 最近是不是也被京东和安卓系统哪个更好用的问题给困扰住了?咱们来好好聊聊这个话题,看看哪个更适合你!京...
安卓跟鸿蒙系统的区别,系统架构... 你有没有发现,现在手机市场上的操作系统真是五花八门,让人挑花了眼?其中,安卓和鸿蒙系统可谓是两大巨头...
让安卓拥有ios系统,揭秘iO... 你知道吗?在科技圈里,最近有个热门话题可是让不少安卓用户心动不已——那就是让安卓拥有iOS系统!想象...
怎样看系统版本安卓,从历史演变... 你有没有发现,手机里的系统版本安卓,就像是它的身份证号码,独一无二,也透露着它的“年龄”和“身份”。...
安卓平板电脑改双系统,轻松实现... 你有没有想过,你的安卓平板电脑可以变身成双系统战士呢?没错,就是那种既能流畅运行安卓应用,又能轻松驾...
屏蔽安卓键盘进不了系统 你是不是也遇到了这个问题?手机屏幕上那个小小的键盘突然变得神秘起来,不管你怎么按,就是进不了系统。别...
跑滴滴用安卓系统好吗,安卓系统... 你有没有想过,跑滴滴的时候用安卓系统到底怎么样呢?这可是个挺实际的问题,毕竟现在手机市场这么丰富,选...
电脑双系统安卓win,安卓与W... 你有没有想过,你的电脑里可以同时装着两个世界?一个世界是熟悉的Windows,另一个世界是充满活力的...
安卓系统手机照片找回,轻松恢复... 手机里的照片丢失了,是不是瞬间感觉心都揪紧了?别慌,今天就来和你聊聊安卓系统手机照片找回的那些事儿,...
安卓系统平板修复方法,安卓平板... 你的安卓系统平板突然罢工了,是不是心里有点慌?别担心,今天就来给你支几招,让你的平板重焕生机! 一、...
forget安卓和ios系统好... 你有没有想过,那些陪伴你走过安卓和iOS系统更迭的好友,如今却因为系统差异而渐行渐远?别急,今天就来...
鸿蒙怎么体验原生安卓系统,体验... 你有没有想过,你的鸿蒙手机也能体验到原生安卓系统的魅力呢?没错,就是那个流畅、自由、充满个性的安卓系...
安卓安装windows双系统,... 你有没有想过,在你的安卓手机上安装一个Windows系统呢?听起来是不是有点不可思议?但别急,今天我...
安卓系统电脑怎么连无线,安卓电... 你有没有想过,家里的安卓系统电脑怎么连上无线网呢?这可是现代生活中的一大必备技能哦!别急,今天就来手...
a20安卓纯净系统,打造极致流... 你有没有想过,手机系统就像是我们生活的环境,有时候太杂乱无章,让人头疼不已。今天,就让我带你走进一个...
原生安卓怎么清理系统,提升性能 你的安卓手机是不是也像你的钱包一样,越用越鼓,里面的“垃圾”越来越多?别急,今天就来教你怎么清理原生...
安卓系统全球装机量多少,引领智... 你有没有想过,那个陪伴我们日常生活的安卓系统,它的全球装机量究竟有多么庞大呢?想象从手机到平板,再到...
安卓系统和emui系统怎么样,... 你有没有发现,现在手机市场上安卓系统和华为的EMUI系统简直就是一对“好基友”啊!它们不仅在国内市场...
安卓44系统怎么升级ios,安... 你有没有想过,把你的安卓手机升级成苹果的iOS系统呢?想象那流畅的操作体验,那独特的应用生态,是不是...