(Java)二叉树的三种遍历(非递归实现)

将上述过程画图说明,便于理解:

参考代码:

public class Solution {

public IList PreorderTraversal(TreeNode root) {

List list = new ArrayList<>();

Stack s = new Stack<>();

if(root==null){

return list;

}

TreeNode cur = root;

s.push(cur);

while(!s.empty()){

cur = s.pop();

while(cur!=null){

list.add(cur.val);

if(cur.right!=null){

s.push(cur.right);

}

cur = cur.left;

}

}

return list;

}

}

非递归实现中序遍历(LeetCode94)

=====================

中序遍历的顺序:左—根—右,将遍历的结果保存在List中

实现非递归遍历借助栈这一数据结构,具体做法如下:

1. 依次将根与左子树的根节点入栈

2. 取出栈顶元素遍历

3. 访问栈顶元素的右子树

4. 栈顶元素右子树也是二叉树,所以将上述操作进行循环

画图说明:

参考代码:

class Solution {

public List inorderTraversal(TreeNode root) {

List list = new ArrayList<>();

Stack s = new Stack<>();

if(root == null){

return list;

}

TreeNode cur = root;

while(!s.empty()||cur!=null){

while(cur!=null){

s.push(cur);

cur = cur.left;

}

cur = s.pop();

list.add(cur.val);

cur = cur.right;

}

return list;

}

}

非递归实现后续遍历(LeetCode145)

=======================

后续遍历顺序:左—右—根,将遍历结果保存在List中

实现非递归后续遍历也得借助栈这一数据结构,具体做法如下:

1. 第一步与中序遍历的操作相同,依次将左子树的根节点保存在栈中

2. 获取栈顶元素,如果该结点的右子树为空,则遍历该结点,否则遍历该结点的右子树

3. 右子树又是一颗二叉树,继续循环上述操作

**注意:****用pre标记每一次遍历的元素,这里每一次获取栈顶元素,当获取栈顶元素的右为空时或者等于标记的结点时,此时都遍历该元素,**这样做目的是防止循环,导致栈溢出。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

分享

1、算法大厂——字节跳动面试题

2、2000页互联网Java面试题大全

3、高阶必备,算法学习

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
大全**

[外链图片转存中…(img-UgM5YyL9-1712544216833)]

3、高阶必备,算法学习

[外链图片转存中…(img-xPRbp67Y-1712544216833)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 28
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java叉树归遍可以通过使用栈数据结构来实现。首先,我们创建一个空的栈,将根节点入栈。然后,我们进入一个循环,直到栈为空为止。在每一次循环中,我们弹出栈顶元素,并将其访问。接下来,如果该节点有右子节点,则将右子节点入栈。如果该节点有左子节点,则将左子节点入栈。由于栈是先进后出的数据结构,所以我们先入栈右子节点,再入栈左子节点,以确保在遍过程中先访问左子树节点。这样就能够实现叉树归遍。 以下是一个示例代码实现叉树归中序遍: ```java public void inorderTraversal(Node root) { if (root == null) { return; } Stack<Node> stack = new Stack<>(); Node current = root; while (current != null || !stack.isEmpty()) { while (current != null) { stack.push(current); current = current.leftChild; } current = stack.pop(); System.out.print(current.data + " "); // 访问节点 current = current.rightChild; } } ``` 在这个示例代码中,我们首先判断当前节点是否为空或者栈是否为空,如果不满足则进入循环。在循环内部,我们首先将当前节点及其所有左子节点入栈,直到当前节点为空。然后,我们弹出栈顶节点并访问该节点。最后,将当前节点更新为其右子节点,并继续下一次循环。 通过这种方式,我们可以实现叉树归中序遍。你可以根据需要修改代码实现其他类型的归遍,比如前序遍和后序遍。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [用Python实现叉树、二叉树归遍及绘制的例子](https://download.csdn.net/download/weixin_38618784/14869891)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [java实现叉树树的归遍](https://blog.csdn.net/weixin_41826973/article/details/105555647)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值