首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

java分层打印二叉树_基于Java的二叉树层序遍历打印实现

大家好,又见面了,我是你们的朋友全栈君。 层序遍历的思路:若树为空,则返回空,否则从树的第一层开始,即从根节点,从上而下逐层遍历。 1....二叉树层序遍历Ⅰ——剑指offer32-Ⅰ 从上到下,从左到右打印二叉树,返回一维数组int[] res。...二叉树层序遍历Ⅱ——剑指offer32-Ⅱ/LeetCode102 从上到下,从左到右打印二叉树,返回List> res。...二叉树层序遍历Ⅲ——剑指offer32-Ⅲ/LeetCode103 从上到下,按zigzag方式打印(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行),返回List> res。...二叉树层序遍历Ⅳ——LeetCode107 从下到上,从左到右打印二叉树,返回List> res。

30910
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    二叉树的建立和遍历

    BinaryTree.png 二叉树:每个结点的子结点个数不大于2的树,叫做二叉树。 根结点:最顶部的那个结点叫做根结点,根结点是所有子结点的共同祖先。比如上图中的“7”结点就是根结点。...子结点:除了根结点外的结点,都叫子结点。 叶子结点:没有子结点的结点,叫做叶子结点。比如上图中的“1”结点、“5”结点和“11”结点。...二叉树的遍历,有三种: (1)前序遍历:先遍历根结点,再遍历左子树,最后遍历右子树。...上图的后序遍历顺序为:1->5->4->11->8->13->12->7 二叉排序树:左子结点 的二叉树,叫做二叉排序树(或排序二叉树)。上图就是一个二叉排序树。...二、二叉树的建立和遍历 #include using namespace std; struct BTreeNode //定义二叉树结点的数据结构 {

    37030

    给出前序遍历和中序遍历求二叉树_已知前序遍历和后序遍历

    一、基本概念 1.先序遍历(NLR)可以确定二叉树的父子结点; 2.中序遍历(LNR)可以确定二叉树的左右子树; 3.后序遍历(LRN)可以确定二叉树的父子结点; 二、结论 1.已知先序遍历,中序遍历序列...,能够创建出一棵唯一的二叉树,可以得出二叉树的后序遍历; 2.已知后序遍历,中序遍历序列,能够创建出一棵唯一的二叉树,进而可以得出二叉树的先序序列; 3.综上,必须含有中序遍历(确定二叉树左右孩子),先序遍历或者后序遍历任选一个...(确定二叉树父子结点),就可以确定一棵唯一的二叉树 三、C++代码实现 1.已知先序遍历和中序遍历,打印后序遍历(见函数void postorder(string preorder, string inorder...)); 2.已知中序遍历和后序遍历,打印先序遍历(见函数void preorder(string inorder, string postorder)); #include #include... using namespace std; /* 假设根节点在中序遍历中的位置为pos,树的结点数为len,即 len=inorder.length() 代码:pos = inorder.find

    59020

    从上到下打印二叉树——层序遍历二叉树

    题目:从上往下打印出二叉树的每个结点,同一层的结点按照从左到右的顺序打印。...二叉树结点的定义如下: struct BinaryTreeNode { int m_nValue; BinaryTreeNode *m_pLeft; BinaryTreeNode...*m_pRight; }; 从上到下打印二叉树的规律:每一次打印一个结点的时候,如果该结点有子结点,则把该结点的子结点放到一个队列的末尾。...接下来到队列的头部取出最早进入队列的结点,重复前面的打印操作,直至队列中所有的结点都被打印出来为止。 既然我们已经确定数据容器是一个队列了,现在的问题就是如何实现队列。...实际上我们无需自己动手实现,因为STL已经为我们实现了一个很好的deque(两端都可以进出的队列)。

    78490

    二叉树进行中序遍历的结果_层次遍历和中序遍历构建二叉树

    大家好,又见面了,我是你们的朋友全栈君。...目录 1.二叉树 2.二叉排序树(搜索树) ---- 1.二叉树 方法:在二叉树下画一条线作为X轴,把所有节点投影到X轴上,从左到右排列好,得到的结果就是中序遍历的结果。...例如: 得到“HDIBEAFJCG”是中序遍历的结果。 在面试或者考试的时候,用上这个小技巧又快又不会出错,绝对是不二选择。...如果想用代码实现的,可以参考这篇文章,二叉树中序遍历(递归+非递归)Java,其中详细介绍了中序遍历实现的方法和结果,包括递归和非递归两种方式。...例如: 得到“10 20 40 50 55 60 62 69 75 80”是中序遍历的结果。 比如要删除20这个节点,那么就是用10或者40这两个节点中的一个替换20。

    38260

    由中序遍历和后序遍历还原二叉树_二叉树的中序列

    大家好,又见面了,我是你们的朋友全栈君。 二叉树的前序遍历、中序遍历和后序遍历之间还原二叉树 1、概念 (1)前序遍历 a、访问根节点;b、前序遍历左子树;c、前序遍历右子树。...2、前序遍历和中序遍历还原二叉树 思想如下: a、根据前序遍历结果,第一个元素为二叉树的根结点; b、观察中序遍历结果,根结点左侧的为左子树,若左子树根结点前(后)再无任何元素,则左(右...中序遍历:CDFEGHAB 求得后序遍历结果为:CFHGEDBA 3、中序遍历和后序遍历还原二叉树 思想如下: a、根据后序遍历结果,最后一个元素为二叉树的根结点; b、观察中序遍历结果...例: 已知 中序遍历:HDIBJEKALFMCNGO 后序遍历: HIDJKEBLMFNOGCA 按照上述步骤先画出二叉树,然后在进行求解前序遍历结果。...结果为: ABDHIEJKCFLMGNO 练习:可参考前序遍历和中序遍历的练习 4、前序遍历和后序遍历还原二叉树 已知前序和中序,后序和中序遍历序列之后,可以唯一确定一棵二叉树。

    46530

    前序遍历和中序遍历树构造二叉树

    题意 根据前序遍历和中序遍历树构造二叉树. 注意事项: 你可以假设树中不存在相同数值的节点 样例 给出中序遍历:[1,2,3]和前序遍历:[2,1,3]....返回如下的树: 2 / \ 1 3 思路 根据前序遍历和中序遍历的规律可得: 前序遍历的第一个就是整个树的根节点 这个根节点在中序遍历的左侧是其左子树,右侧是右子树。...将每一个节点都看作是一个单独的树,根据此 规律1 和 规律2 依次递归获取其左右子树的前序与中序遍历,直到前序遍历或中序遍历的长度仅剩1,则说明该节点为叶子节点,从而构造整棵树。...]; //右侧子节点的前序遍历 //从现有的中序遍历中拿到 左右子节点的中序遍历 for (int i = 0; i < inorder.length; i++) { if...treeRoot.right = buildTree(child_PreorderRight,child_InorderRight); return treeRoot; } } 原题地址 LintCode:前序遍历和中序遍历树构造二叉树

    1.8K40

    已知前序遍历和中序遍历求二叉树

    大家好,又见面了,我是你们的朋友全栈君。 描述 输入某二叉树的前序遍历和中序遍历的结果,请输出后序遍历序列。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。...例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},重建二叉树并返回后序遍历序列 输入 输入某二叉树的前序遍历和中序遍历的结果 输出 输出后序遍历序列...中序遍历为先访问左子树,然后是根节点,右子树 所以通过前序遍历不断地找到根节点,然后中序遍历找到其左子树和右子树 最后就可以得到这棵二叉树,后序遍历即为 7 4 2 5 8 6 3 1 实现代码...else { in[incount]=in[incount]*10+(inn[i]-'0'); } } } } //如果前序遍历的结点数与中序遍历的结点数相同且不为...0,那么可以找到对应二叉树 if(precount==incount&&precount!

    37210

    二叉树的先序,中序,后序遍历的序列_二叉树先序遍历和后序遍历正好相反

    二叉树的遍历主要有三种: (1)先(根)序遍历(根左右) (2)中(根)序遍历(左根右) (3)后(根)序遍历(左右根) 举个例子: 先(根)序遍历(根左右):A B D H E I C F J K...此外,还有一个命题:给定了二叉树的任何一种遍历序列,都无法唯一确定相应的二叉树。但是如果知道了二叉树的中序遍历序列和任意的另一种遍历序列,就可以唯一地确定二叉树。...例子1:已知二叉树的后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是(cedba)。...(3)中序遍历:ba 后序遍历:ab 由后序遍历序列可知b为e的右子树的根结点。由中序遍历序列中可看出,a为根结点b的右子结点。...b','e','c'] center = ['d','e','b','a','c'] t = rebuild(rear, center) pre_order(t) 例子2:已知二叉树的前序遍历序列是

    59020

    二叉树的遍历——递归和非递归

    二 叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有前序、中序以及后序三种遍历方法。...在三种遍历中, 前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点。 一.前序遍历    前序遍历按照“根结点-左孩子-右孩子”的顺序进行访问。  ...        根据前序遍历访问的顺序,优先访问根结点,然后再分别访问左孩子和右孩子。...因为在后序遍历中,要保证左孩子和右孩子都已被访问并且左孩子在右孩子前访问才能访问根结点,这就为流程的控制带来了难题。下面介绍两种思路。       ...= NULL)               q.push(p->rchild);       }   }   五.二叉树的其他一些应用 1.求二叉树的深度 若一棵二叉树为空,则它的深度为0,否则它的深度等于左子树和右子树中的最大深度加

    1.2K80

    二叉树的基本概念和遍历

    判断是否是完全二叉树的步骤: 层序遍历二叉树; 如果存在一个节点的右子树存在而左子树不存在,则直接返回false 如果当前节点的左子树和右子树不同时存在,则其后的节点的左右子树均不存在,如果存在,则直接返回...前驱节点:指的是这个节点在中序遍历序列中的上一个节点 二、二叉树的遍历   二叉树的遍历方法有多种,首先我想先改变这几个遍历的名字(前根序遍历,中根序遍历,后根序遍历);前中后本来就是相对于根结点来说的...,具体步骤如下: 申请一个栈,记为stack,将头结点压入stack,同时设置两个变量h和cur,在整个流程中,h代表最近一次弹出并打印的节点,cur代表当前stack的栈顶节点,初始时令h为头结点,cur...:按层的顺序打印节点,每一层从左到右打印,上图中的层序遍历结果是:ABCDEFGH 用队列作为辅助结构进行输出,然后用变量last表示当前行的最后节点,变量nextLast表示下一行的最后节点 1...根据遍历结果我们可以构造出原始的二叉树,在此过程中我们只能通过二叉树的先序+中序或中序+后序来构造: 已知一棵二叉树的先序序列和中序序列,构造该二叉树的过程如下: 根据前根序序列的第一个元素建立根结点

    671100

    python实现二叉树层序遍历(逐层打印二叉树)「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 题目要求 给定一个二叉树,要求从上往下逐层打印该二叉树节点的值,每层从左往右打印。...解题思路——广度优先遍历 实际上就是广度优先遍历, 借助一个队列(这里用数组代替)就可以实现: 1、先将root节点加入队列 2、队列不为空时取队列首节点 3、打印节点的值,然后将该节点的左、右子节点先后加入队尾...(核心步骤,广度优先体现在这) 4、回到2,直到队列为空 该方法对满二叉树和非满二叉树都符合题目要求。...先从打印一行开始 一步一步来,我们先将所有节点的值按层序打印在一行,即每层之间不换行。后面的函数都是基于这个母版进行的改进。...if node.right: queue.append([line+1, node.right]) # 将本节点的行号和右子节点入队 4.

    1.1K20

    二叉树的遍历

    从基本概念、Java 驱动使用、数据操作、安全性能问题与解决、数据一致性事务处理,到数据模型设计、技术集成和存储图片优势等方面讲解详细、条理清晰,体现出作者深入的理解。...前言二叉树有三种遍历方式,三种遍历方式的核心都是把一颗二叉树分为根、左子树、右子树三部分。前中后其实说的是根出现的顺序,在二叉树中左子树遍历顺序始终先于右子树。...(根1的左子树)->(根2的左子树)->N(根3的左子树)->根3->N(根3的右子树)2的左子树遍历完,返回遍历根2和根2的右子树(根1的左子树)->(根2的左子树)->N(根3的左子树)->根3-...>N(根3的右子树)->根2->N(2的右子树)根2和根2的右子树遍历完(也就是根1的左子树遍历完),返回遍历根1和根1的右子树(根1的左子树)->(根2的左子树)->N(根3的左子树)->根3->N(...1三种遍历结果汇总代码实现(核心:递归)定义一个二叉树的结构体,里面包含左子树指针,右子树指针,数据先造一棵链式二叉树出来先造一棵链式二叉树出来#include#include<stdlib.h

    7920
    领券