九、二叉树
创始人
2024-05-29 17:58:00
0

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

自学JAVA数据结构笔记,跟学视频为:黑马程序员Java数据结构与java算法全套教程,数据结构+算法教程全资料发布,包含154张java数据结构图_哔哩哔哩_bilibili


提示:以下是本篇文章正文内容,下面案例可供参考

一、树的基本定义

1.含义

树是我们计算机中非常重要的一种数据结构,同时使用树这种数据结构,可以描述现实生活中的很多事物,例如家 谱、单位的组织架构、等等。

树是由n(n>=1)个有限结点组成一个具有层次关系的集合。把它叫做“树”是因为它看起来像一棵倒挂的树,也就 是说它是根朝上,而叶朝下的。

2.特点

树具有以下特点:

1.每个结点有零个或多个子结点;

2.没有父结点的结点为根结点;

3.每一个非根结点只有一个父结点;

4.每个结点及其后代结点整体上可以看做是一棵树,称为当前结点的父结点的一个子树;

二、树的相关术语

结点的度:

一个结点含有的子树的个数称为该结点的度;

叶结点:

度为0的结点称为叶结点,也可以叫做终端结点

分支结点:

度不为0的结点称为分支结点,也可以叫做非终端结点

结点的层次:

从根结点开始,根结点的层次为1,根的直接后继层次为2,以此类推

结点的层序编号:

将树中的结点,按照从上层到下层,同层从左到右的次序排成一个线性序列,把他们编成连续的自然数。

树的度:

树中所有结点的度的最大值

树的高度(深度):

树中结点的最大层次

森林:

m(m>=0)个互不相交的树的集合,将一颗非空树的根结点删去,树就变成一个森林;给森林增加一个统一的根 结点,森林就变成一棵树

三、二叉查找树的创建

1.结点类

结点类API设计:

类名                 Node

构造方法         Node(Key key, Value value, Node left, Node right):创建Node对象

成员变量         1.public Node left:记录左子结点

                        2.public Node right:记录右子结点

                        3.public Key key:存储键

                        4.public Value value:存储值

代码实现: 

private class Node{//存储键public Key key;//存储值private Value value;//记录左子结点public Node left;//记录右子结点public Node right;public Node(Key key, Value value, Node left, Node right) {this.key = key;this.value = value;this.left = left;this.right = right;}
}

 2. 二叉查找树

二叉查找树API设计:

类名                 BinaryTree,Value value>

构造方法         BinaryTree():创建BinaryTree对象

成员变量         1.private Node root:记录根结点

                        2.private int N:记录树中元素的个数

成员方法         1. public void put(Key key,Value value):向树中插入一个键值对

                        2.private Node put(Node x, Key key, Value val):给指定树x上,添加键一个键值对,并返回添 加后的新树

                        3.public Value get(Key key):根据key,从树中找出对应的值

                        4.private Value get(Node x, Key key):从指定的树x中,找出key对应的值                         5.public void delete(Key key):根据key,删除树中对应的键值对

                        6.private Node delete(Node x, Key key):删除指定树x上的键为key的键值对,并返回删除后的新树

                        7.public int size():获取树中元素的个数

 二叉查找树实现:

package BinaryTree;public class BinaryTree, Value> {//记录根结点private Node root;//记录树中元素的个数private int N;//获取树中元素的个数public int size() {return N;}//向树中添加元素key-valuepublic void put(Key key, Value value) {root = put(root, key, value);}//向指定的树x中添加key-value,并返回添加元素后新的树private Node put(Node x, Key key, Value value) {//当跟结点为空if (x == null) {//个数+1N++;return new Node(key, value, null, null);}//比较数int cmp = key.compareTo(x.key);if (cmp > 0) {//新结点的key大于当前结点的key,继续找当前结点的右子结点x.right = put(x.right, key, value);} else if (cmp < 0) {//新结点的key小于当前结点的key,继续找当前结点的左子结点x.left = put(x.left, key, value);} else {//新结点的key等于当前结点的key,把当前结点的value进行替换x.value = value;}return x;}//查询树中指定key对应的valuepublic Value get(Key key) {return get(root, key);}//从指定的树x中,查找key对应的值public Value get(Node x, Key key) {if (x == null) {return null;}int cmp = key.compareTo(x.key);if (cmp > 0) {//如果要查询的key大于当前结点的key,则继续找当前结点的右子结点;return get(x.right, key);} else if (cmp < 0) {//如果要查询的key小于当前结点的key,则继续找当前结点的左子结点;return get(x.left, key);}else {//如果要查询的key等于当前结点的key,则树中返回当前结点的value。return x.value;}}//删除树中key对应的valuepublic void delete(Key key) {root = delete(root, key);}//删除指定树x中的key对应的value,并返回删除后的新树public Node delete(Node x, Key key) {if (x == null) {return null;}int cmp = key.compareTo(x.key);if (cmp > 0) {//新结点的key大于当前结点的key,继续找当前结点的右子结点x.right = delete(x.right, key);} else if (cmp < 0) {//新结点的key小于当前结点的key,继续找当前结点的左子结点x.left = delete(x.left, key);} else {//新结点的key等于当前结点的key,当前x就是要删除的结点//1.如果当前结点的右子树不存在,则直接返回当前结点的左子结点if (x.right == null) {return x.left;}//2.如果当前结点的左子树不存在,则直接返回当前结点的右子结点if (x.left == null) {return x.right;}//3.当前结点的左右子树都存在//3.1找到右子树中最小的结点Node minNode = x.right;while (minNode.left != null) {minNode = minNode.left;}//3.2删除右子树中最小的结点Node n = x.right;while (n.left != null) {if (n.left.left == null) {n.left = null;} else {n = n.left;}}//3.3让被删除结点的左子树称为最小结点minNode的左子树,让被删除结点的右子树称为最小结点minNode的右子树minNode.left = x.left;minNode.right = x.right;//3.4让被删除结点的父节点指向最小结点minNodex = minNode;//个数-1N--;}return x;}private class Node {//存储键public Key key;//存储值private Value value;//记录左子结点public Node left;//记录右子结点public Node right;public Node(Key key, Value value, Node left, Node right) {this.key = key;this.value = value;this.left = left;this.right = right;}}
}

总结

提示:这里对文章进行总结:
 

相关内容

热门资讯

安卓系统用的华为应用,探索智能... 你知道吗?在安卓系统里,华为的应用可是个宝库呢!它们不仅功能强大,而且使用起来超级方便。今天,就让我...
安卓变ios系统魅蓝 你知道吗?最近有个朋友突然告诉我,他要把自己的安卓手机换成iOS系统,而且还是魅蓝品牌的!这可真是让...
幻书启世录安卓系统,安卓世界中... 亲爱的读者们,你是否曾在某个夜晚,被一本神奇的书所吸引,仿佛它拥有着穿越时空的力量?今天,我要带你走...
电脑安装安卓系统进不去,安卓系... 电脑安装安卓系统后竟然进不去,这可真是让人头疼的问题啊!你是不是也遇到了这种情况,心里直呼“怎么办怎...
用键盘切换控制安卓系统,畅享安... 你有没有想过,用键盘来控制你的安卓手机?是的,你没听错,就是那个我们每天敲敲打打的小玩意儿——键盘。...
小米安卓镜像系统在哪,小米安卓... 你有没有想过,你的小米手机里有一个隐藏的宝藏——安卓镜像系统?没错,就是那个可以让你的手机瞬间变身成...
安卓手机下载排班系统,高效排班... 你有没有想过,每天忙碌的工作中,有没有什么好帮手能帮你轻松管理时间呢?今天,就让我来给你介绍一个超级...
桌面组件如何弄安卓系统,桌面组... 亲爱的桌面爱好者们,你是否曾梦想过将安卓系统搬到你的电脑桌面上?想象那些流畅的动画、丰富的应用,还有...
安卓13系统介绍视频,新功能与... 亲爱的读者们,你是否对安卓13系统充满好奇?想要一探究竟,却又苦于没有足够的时间去研究?别担心,今天...
车机安卓7.1系统,功能升级与... 你有没有发现,现在的车机系统越来越智能了?尤其是那些搭载了安卓7.1系统的车机,简直就像是个贴心的智...
安卓系统下如何读pdf,And... 你有没有遇到过这种情况:手机里存了一大堆PDF文件,可是怎么也找不到一个能顺畅阅读的工具?别急,今天...
安卓系统全国通用的吗,畅享智能... 你有没有想过,为什么你的手机里装的是安卓系统呢?安卓系统,这个名字听起来是不是有点神秘?今天,就让我...
假苹果手机8安卓系统,颠覆传统... 你有没有想过,如果苹果手机突然变成了安卓系统,会是怎样的景象呢?想象那熟悉的苹果外观,却运行着安卓的...
安卓12.0系统vivo有吗,... 你有没有听说最近安卓系统又升级啦?没错,就是那个让手机焕然一新的安卓12.0系统!那么,咱们国内的手...
核心芯片和安卓系统,探索核心芯... 你知道吗?在科技的世界里,有一对“黄金搭档”正悄悄改变着我们的生活。他们就是——核心芯片和安卓系统。...
如何调安卓系统屏幕颜色,安卓系... 亲爱的手机控们,你是否曾觉得安卓系统的屏幕颜色不够个性,或者是因为长时间盯着屏幕而感到眼睛疲劳?别担...
旧台式电脑安装安卓系统,轻松安... 你那台旧台式电脑是不是已经服役多年,性能逐渐力不从心,却又不忍心让它退役呢?别急,今天就来教你怎么给...
美国要求关闭安卓系统,科技霸权... 美国要求关闭安卓系统:一场技术革新还是政治博弈?在数字化时代,智能手机已经成为我们生活中不可或缺的一...
安卓系统日记本 你有没有发现,手机里的安卓系统日记本,简直就是记录生活点滴的宝藏库呢?想象每天忙碌的生活中,有没有那...
安卓手机广告最少的系统,探索安... 你有没有发现,用安卓手机的时候,广告总是无处不在,让人烦得要命?不过别急,今天我要给你揭秘一个秘密—...