广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >二叉树遍历方法——前、中、后序遍历(java)
  • 445
分享到

二叉树遍历方法——前、中、后序遍历(java)

算法 2023-09-20 16:09:27 445人浏览 安东尼
摘要

二叉树结构: static class Treenode{ public char val; public TreeNode left; public TreeNode right;

二叉树结构:

static class Treenode{        public char val;        public TreeNode left;        public TreeNode right;        public TreeNode(char val) {            this.val = val;        }        @Override        public String toString() {            return this.val+"";        }    }

一、前序遍历

前序遍历是一种访问二叉树的每一个结点的方法,它的遍历顺序是根节点,左子树,右子树。

1)递归版本

public void preOrder1(TreeNode root){        if(root==null){            return ;        }        System.out.println(root.val);        preOrder1(root.left);        preOrder1(root.right);    }

递归版本其实很简单,就是按照它的遍历方式来写一下就可以,我们主要来介绍一下非递归的方法。

2)非递归版本

前序遍历的非递归方式就是将递归的版本的每一个过程都存储下来,而我们就需要一个辅助栈来帮助我们实现。

算法思想:

节点不为空,打印,入栈,遍历左子树

节点为空但是栈不为空,出栈顶元素,遍历栈顶元素右子树

节点为空栈也为空,结束程序

二叉树为空结束程序

按照上述的代码思路,我们可以实现代码如下:

    public void preOrder2(TreeNode root){        Stack stack = new Stack<>();        TreeNode cur = root;        while(!stack.empty()||cur!=null){            if(cur!=null){                //打印根节点                System.out.print(cur.val+" ");                //根节点入栈                stack.push(cur);                //访问左子树                cur=cur.left;            }            else{                cur=stack.pop().right;            }        }    }

运行结果:

 二、中序遍历

中序遍历的顺序是左子树、根节点、右子树,所以递归的版本可以按照前序遍历的思路来实现。

1)递归版本

public void inOrder1(TreeNode root){        if(root==null){            return ;        }        inOrder1(root.left);        System.out.print(root.val+" ");        inOrder1(root.right);    }

2)非递归版本

算法思想:

节点不为空,入栈,访问左子树

节点为空但是栈不为空,出栈顶元素,打印,访问栈顶元素的右子树

栈为空并且节点为空,结束遍历

二叉树为空结束遍历

下面是中序遍历的非递归形式的代码实现:

    public void inOrder2(TreeNode root){        Stack stack = new Stack<>();        TreeNode cur = root;        while(!stack.empty()||cur!=null){            if(cur!=null){                stack.push(cur);                cur=cur.left;            }            else{                cur=stack.pop();                System.out.print(cur.val+" ");                cur=cur.right;            }        }    }

运行结果:

 

三、后序遍历

后序遍历的顺序是左子树、右子树、根节点。

递归版本

public void postOrder1(TreeNode root){        if(root==null){            return ;        }        postOrder1(root.left);        postOrder1(root.right);        System.out.println(root.val);    }

非递归版本

后序遍历和前两个的遍历方法会有写不同,我们拿中序遍历来说,中序遍历是在遍历完左子树的时候,出根节点,打印根节点,访问右子树,但是后序遍历我们在访问左子树的之后需要访问右子树,在访问根节点,所以我们根节点不能在访问左子树之后出栈,需要继续访问右子树,当我们右子树访问完之后再出栈,所有我们就是必须需要

算法思路:

遍历左子树并且将左子树入栈

左子树为空的时候,访问右子树,有两种可能右子树为空:打印根节点,标记根节点,防止重复打印;树不为空,继续访问右子树的左子树,重复上诉过程

public void postOrder2(TreeNode root){        Stack stack = new Stack<>();        TreeNode cur = root;        TreeNode prev = null;        while(cur!=null||stack.empty()){            while(cur!=null){                stack.push(cur);                cur=cur.left;            }            TreeNode top = stack.peek();            if(top.right==null||top.right==prev){                System.out.print(top.val+" ");                prev=top;                stack.pop();            }            else{                cur=top.right;            }        }    }

运行结果: 

 解释一下prev:

我们的二叉树当我们左子树遍历到D的时候我们的栈有A、B、D此时右子树不为空继续遍历栈中加入H元素此时栈顶元素为H,其右子树为空我们打印H,删除栈顶元素H,按照程序继续走我们现在栈顶元素是D,D的右子树不为空继续将H加入栈中此时会出现死循环,所以我们需要用一个prev表示上一次打印元素,防止重复进入栈。

 

 

来源地址:https://blog.csdn.net/loss_rose777/article/details/131399871

--结束END--

本文标题: 二叉树遍历方法——前、中、后序遍历(java)

本文链接: https://www.lsjlt.com/news/413079.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 二叉树遍历方法——前、中、后序遍历(java)
    二叉树结构: static class TreeNode{ public char val; public TreeNode left; public TreeNode right; ...
    99+
    2023-09-20
    算法
  • N叉树的三种遍历(层次遍历、前序遍历、后序遍历)
    目录题目链接:1、层次遍历2、前序遍历3、后序遍历题目链接: 590.N叉树的后序遍历 429.N叉树的层序遍历 598.N叉树的前序遍历 1、层次遍历 """ # Definit...
    99+
    2022-11-13
  • c语言二叉树的前序遍历方法
    这篇文章主要讲解了“c语言二叉树的前序遍历方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“c语言二叉树的前序遍历方法”吧!题目给定一个二叉树,返回它的 前序 遍历。示例:输入: [1,nu...
    99+
    2023-06-19
  • 二叉树的中序遍历
    解题思路: 官方题解中介绍了三种方法来完成树的中序遍历,包括: 递归 借助栈的迭代方法 莫里斯遍历 在树的深度优先遍历中(包括前序、中序、后序遍历),递归方法最为直观易懂,但考虑到效率,我们通常不推荐使用递归。 栈迭代方法虽然提高了效率,但...
    99+
    2023-10-07
    python
  • Java 二叉树遍历特别篇之Morris遍历
    在前面,我们简单提及过二叉树的遍历方式,有递归和非递归两个版本的遍历。仔细想一想,不管是递归的,还是非递归的遍历,两种版本的遍历都是需要耗费大量的、额外的空间。比如当我们二叉树的高度...
    99+
    2022-11-12
  • Java 二叉树遍历的常用方法
    目录递归方式非递归方式层次遍历总结采用前序遍历、中序遍历、后续遍历实现时,即便采用不同的实现方式(递归方式、非递归),它们的算法结构是有很大的相似性。因而针对前三种的遍历我们会总结出...
    99+
    2022-11-12
  • Python 递归式实现二叉树前序,中序,后序遍历
    目录1.前序遍历2.中序遍历3.后序遍历4.测试5.结果6.补充6.1N叉树前序遍历记忆点: 前序:VLR中序:LVR后序:LRV 举例: 一颗二叉树如下图所示: 则它的前序、中...
    99+
    2022-11-13
  • C++非递归实现二叉树的前中后序遍历
    目录二叉树的前序遍历二叉树的中序遍历二叉树的后序遍历二叉树的前序遍历 在不使用递归的方式遍历二叉树时,我们可以使用一个栈模拟递归的机制。二叉树的前序遍历顺序是:根 → 左子树 → ...
    99+
    2022-11-12
  • java二叉树的遍历方式详解
    目录一、前序遍历(递归和非递归)二、中序遍历(递归和非递归)三、后序遍历(递归和非递归)四、层序遍历总结一、前序遍历(递归和非递归) 前序遍历就是先遍历根再遍历左之后是右 根左右 ...
    99+
    2022-11-12
  • C++实现二叉树层序遍历的方法
    今天小编给大家分享一下C++实现二叉树层序遍历的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。二叉树层序遍历Given ...
    99+
    2023-06-19
  • Java数据结构最清晰图解二叉树前中后序遍历
    目录一,前言二,树①概念②树的基础概念三,二叉树①概念②两种特殊的二叉树③二叉树的性质四,二叉树遍历①二叉树的遍历②前序遍历③中序遍历④后序遍历五,完整代码一,前言 二叉树是数据结构...
    99+
    2022-11-13
  • java非递归实现之二叉树的前中后序遍历详解
    二叉树的前中后序遍历 核心思想:用栈来实现对节点的存储。一边遍历,一边将节点入栈,在需要时将节点从栈中取出来并遍历该节点的左子树或者右子树,重复上述过程,当栈为空时,遍历完成。 前序...
    99+
    2022-11-12
  • C语言二叉树层序遍历
    实现下面图中的二叉树层序遍历 #include <stdio.h> #include <stdlib.h> #include <stdbool.h&g...
    99+
    2022-11-13
  • python先序遍历二叉树问题
    问题 如何遍历一个二叉树 遍历二叉树就是访问二叉树的每一个节点 二叉树父结点下先左访问,先序遍历(根左右) 例如:遍历以下的二叉树 遍历结果:ABDECF Python代码示例 # !/usr/bi...
    99+
    2022-06-04
    遍历 二叉树 python
  • JavaScript实现二叉树层序遍历
    目录题目描述示例递归实现代码思路解析图示队列实现代码思路解析题目描述 给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。 示例 二叉树:[3...
    99+
    2023-05-14
    JavaScript二叉树遍历 JS遍历 二叉树层序遍历 JS二叉树
  • 怎么解析python二叉树的后序遍历
    怎么解析python二叉树的后序遍历,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。二叉树的后序遍历题目给定一个二叉树,返回它的 后序 遍历。 示例:输入: [1,...
    99+
    2023-06-19
  • C++实现LeetCode(145.二叉树的后序遍历)
    [LeetCode] 145. Binary Tree Postorder Traversal 二叉树的后序遍历 Given a binary tree, return the po...
    99+
    2022-11-12
  • C++怎么实现二叉树的后序遍历
    这篇文章主要介绍“C++怎么实现二叉树的后序遍历”,在日常操作中,相信很多人在C++怎么实现二叉树的后序遍历问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++怎么实现二叉树的后序遍历”的疑惑有所帮助!接下来...
    99+
    2023-06-20
  • C语言中二叉树的后序遍历详解
    目录一.二叉树的后序遍历.(递归)二.二叉树的后序遍历(迭代)总结首先我们从两个方面讲解二叉树的后序遍历(递归+迭代) 一.二叉树的后序遍历.(递归) 思想: 首先我们从二叉树的根节...
    99+
    2022-11-13
  • Java二叉树的遍历方式有哪些
    本篇内容主要讲解“Java二叉树的遍历方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java二叉树的遍历方式有哪些”吧!二叉树的四种遍历方式:二叉树的遍历(traversing bin...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作