二叉树知识锦囊(二)
创始人
2024-05-19 09:48:14
0

作者:爱塔居

专栏:数据结构

作者简介:大三学生,希望和大家一起进步!

文章目录

文章目录

一、二叉树的存储

二、二叉树的遍历(重点)

2.1 前序遍历

 2.2 中序遍历

 2.3 后序遍历

2.4 层序遍历

 2.5 小题实练

三、代码实现


一、二叉树的存储

二叉树的存储结构分为:顺序存储和类似于链表的链式存储。

二叉树的链式存储是通过一个一个的节点引用起来的,常见的表示方式有二叉和三叉表示方法。

二、二叉树的遍历(重点)

遍历是指沿着某条搜索路线,依次对树中的每个节点,均做一次且仅做一次访问。访问结点所做的操作依赖于具体的应用问题。

2.1 前序遍历

前序遍历:根结点》左子树》右子树

前序遍历:

 从A开始,打印A往左走,遍历到B,打印B,再遍历B的左子树D,打印D,接着遍历D的左子树,发现为空,返回D,再遍历D的右子树G,打印G,遍历G的左右子树都为空,返回G,返回D,返回B,遍历B的右子树为空,返回B,返回A。A\rightarrow B\rightarrow D\rightarrow G

 再遍历A的右子树C,打印C,遍历C的左子树F,打印F,再遍历F的左右子树为空,返回F,返回C,再遍历C的右子树K,打印K,遍历K的左右子树为空,返回K,返回C,返回A。C\rightarrow F\rightarrow K

所以这个二叉树的前序遍历为A\rightarrow B\rightarrow D\rightarrow G\rightarrow C\rightarrow F\rightarrow K

 2.2 中序遍历

中序遍历:左子树》根》右子树

从A开始,到A的左子树B,遍历B的左子树D,遍历D的左子树为空,返回D,打印D,遍历D的右子树G,遍历G的左子树为空,返回G,打印G,遍历G的右子树为空,返回G,返回D,返回B,打印B,遍历B的右子树为空,返回B,返回A,打印A。D\rightarrow G\rightarrow B\rightarrow A

再遍历A的右子树C,遍历C的左子树F,遍历F的左子树为空,返回F,打印F,遍历F的右子树为空,返回F,返回C,打印C,遍历C的右子树K,遍历K的左子树为空,返回K,打印K,遍历K的右子树为空,返回K,返回C,返回A。F\rightarrow C\rightarrow K

故该二叉树的中序遍历为D\rightarrow G\rightarrow B\rightarrow A\rightarrowF\rightarrow C\rightarrow K

 2.3 后序遍历

后序遍历:左子树》右子树》根 

从A开始,遍历A的左子树B,遍历B的左子树D,遍历D的左子树为空,返回D,遍历D的右子树G,遍历G的左右子树为空,返回G,打印G,返回D,打印D,返回B,遍历B的右子树为空,返回B,打印B ,返回A。G\rightarrow D\rightarrow B

遍历A的右子树C,遍历C的左子树F,遍历F的左右子树为空,返回F,打印F,返回C,遍历C的右子树K,遍历K的左右子树为空,返回K,打印K,返回C,打印C,返回A,打印A。F\rightarrow K\rightarrow C\rightarrow A

故该二叉树的后序遍历为G\rightarrow D\rightarrow B\rightarrowF\rightarrow K\rightarrow C\rightarrow A

2.4 层序遍历

层序遍历就是自上而下,自左至右访问树的结点的过程。

这个二叉树的层序遍历为A\rightarrow B\rightarrow C\rightarrow D\rightarrow F\rightarrow K\rightarrow G

 2.5 小题实练

1.某完全二叉树按层次输出(同一层从左到右)的序列为 ABCDEFGH 。该完全二叉树的前序序列为()
A: ABDHECFG B: ABCDEFGH C: HDBEAFCG D: HDEBFGCA

 因为是完全二叉树,所以我们根据层序遍历的结果可以画出二叉树:

 根据二叉树,我们得出前序遍历结果ABDHECFG

2.二叉树的先序遍历和中序遍历如下:先序遍历:EFHIGJK;中序遍历:HFIEJKG.则二叉树根结点为()
A: E B: F C: G D: H

先序遍历第一个结点就是根结点,故为A;

如果这道题要我们画出这个二叉树,我们也可以画出:

 因为中序遍历顺序,根结点的左边结点都是在左边,右边的结点都是在右边。

3.设一课二叉树的中序遍历序列:badce,后序遍历序列:bdeca,则二叉树前序遍历序列为()
A: adbce B: decab C: debac D: abcde

 根据中序遍历和后序遍历结果画出二叉树图为:

前序遍历结果:abcde

4.某二叉树的后序遍历序列与中序遍历序列相同,均为 ABCDEF ,则按层次输出(同一层从左到右)的序列为()
A: FEDCBA B: CBAFED C: DEFCBA D: ABCDEF

层序遍历结果:FEDCBA

🍓那如果知道前序遍历序列和后序遍历序列,我们可以画出二叉树吗?

答案是不行。因为这样,我们只能找到根结点,不能确定左子树和右子树的位置。

三、代码实现

接下来,我们尝试着创建一个二叉树。

public  class TestBinaryTree {
static  class  TreeNode {public char val;//数据域public TreeNode left;//左孩子节点public TreeNode right;//右孩子节点public TreeNode(char val) {this.val = val;}
}public TreeNode createTree( ){TreeNode A=new TreeNode('A');TreeNode B=new TreeNode('B');TreeNode C=new TreeNode('C');TreeNode D=new TreeNode('D');TreeNode E=new TreeNode('E');TreeNode F=new TreeNode('F');TreeNode G=new TreeNode('G');TreeNode H=new TreeNode('H');A.left=B;A.right=C;B.left=D;B.right=E;C.left=F;C.right=G;E.right=H;return A;}

 先序遍历:

public void preOrder(TreeNode root){//当二叉树根结点为空if(root==null){return;}//不为空,打印树的根结点的值System.out.print(root.val+" ");//这时对左子树进行先序遍历,又是新的二叉树preOrder(root.left);preOrder(root.right);
}

中序遍历:

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

 后序遍历:

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

完整代码见链接:javacode: java的日常代码---------------------- - Gitee.com 

相关内容

热门资讯

安徒生童话好词好句 安徒生童话好词好句  提起《安徒生童话》,恐怕世界上没有人不知道了,安徒生童话好词好句。有令人捧腹大...
阿拉伯寓言故事《爱与恨》 阿拉伯寓言故事《爱与恨》  爱与恨  一个女人和一个男人说:“我爱你。”男人说:“对你的爱我受之无愧...
适合胎教的英语故事   现代科学的发展已证明,胎儿不仅具有视觉、听觉、活动和记忆能力,而且能够感受母亲的情绪变化。下面是...
小学生道德故事   下面是小编整理的小学生道德故事,欢迎阅读! 小学生道德故事篇一:草与秧苗  孔子东游,见田...
童话 英文版 童话 英文版  The Black Cat黑猫的英文版童话,希望大家喜欢。  英文版童话之The B...
短篇儿童故事   下面是小编整理的短篇儿童故事,希望能够给小朋友们带来欢乐,欢迎阅读!  一、小猪变干净了  有一...
秋天的童话故事 秋天的童话故事(精选30篇)  故事一般都和原始人类的生产生活有密切关系,他们迫切地希望认识自然,于...
世说新语中的故事 世说新语中的故事  故事一般都和原始人类的生产生活有密切关系,他们迫切地希望认识自然,于是便以自身为...
端午节的由来 端午节的由来  导语:我们的端午佳节是怎么发展而产生的,这里面有什么故事大家都了解吗?下面是小编为大...
格林童话《刺猬汉斯》原文 格林童话《刺猬汉斯》原文  文字像精灵,只要你用好它,它就会产生让你意想不到的效果。所以无论我们说话...
小白兔乖乖故事作文 小白兔乖乖故事作文(精选20篇)  在日常学习、工作抑或是生活中,大家或多或少都会接触过作文吧,作文...
伤感的爱情故事 故事结局无法在一起的男女主人公的爱情故事总是让人伤感,深爱的一方爱情不能得到好的归宿是最令众人唏嘘的...
革命小故事 革命小故事  故事的特点  语言富于动性。  故事不需要有过多的心理活动描写、大段的对话和繁复细腻的...
情人节的趣事   情人节那天闲来无事,无意间看到了有趣的爱情故事。这个故事很简单,而主人公也只有三个人,红、黄、蓝...
女巫的魔法帽的童话故事 女巫的魔法帽的童话故事  女巫天生爱美,穿着时尚,喜欢逛街、购物,当然啦,因为她还要有相搭配的鞋子,...
蓝精灵的新故事 -作文 蓝精灵的新故事 -作文又是一个星期日,蓝精灵的新故事。我一觉醒来,突然发现有什么不对劲——一只只蓝精...
经典儿童睡前小故事集锦   孩子哭闹不睡觉怎么办?讲讲小故事吧,很有效果的。  1.《一棵快乐的树》  从前有一棵树,她好爱...
伊索寓言故事七则 伊索寓言带给我们智慧和为人处世的道理,伊索寓言通常篇章比较简短,故事主角大多为人或者动物,故事生动有...
雷达树童话故事 雷达树童话故事  大橡树一举成名  这是一个寻常的小镇,小镇上住着一个叫米米的寻常该子,米米家门前有...
后羿射日的神话故事 后羿射日的神话故事  故事:在现实认知观的基础上,对其描写成非常态性现象。是文学体裁的一种,侧重于事...