二叉检索树 及 插入方法的图解、实现、时间代价分析

1、二叉检索树:

(1)定义

二叉检索树的任意一个结点,设其值为k,则该节点左子树中任意一个结点的值都小于k;该节点右子树中任意一个节点的值都大于或等于k
这里的比较规则可以是针对数字的,也可以是针对字符串的,总之只要该数据项具有可比较的规则,就可以用二叉检索树这样的结构存储
在这里插入图片描述
当二叉检索树结点中存放的数据元素是数字时对二叉检索树进行中序遍历得到一个递增的有序序列
在这里插入图片描述

(2)二叉检索树存在的意义:

数据结构存在的目的是为了用户对数据集合的各种操作(CRUD:增删改查)更便捷快速

对比之前学过的顺序表和链表,二叉树相当于在两者中取了平衡
在这里插入图片描述
增加删除操作背后原理相同,改在查的基础上完成,因此上面的表格可简化成:
在这里插入图片描述

(3)二叉树结点中的内容不一定是数字

前面提到只要数据集合中的数据元素中含有可以比较的数据项,那么就可以采用二叉检索树这样的数据结构
在这里插入图片描述
整个二叉检索树存放数据集合,数据元素存放在二叉树结点中,数据项作为对数据元素进行 增删改查 的key

2、英文字符串的比较规则

(1)示例

在这里插入图片描述

(2)比较规则

在英文字符串的比较中,比较步骤通常遵循字典顺序,即ASCII码的顺序。首先,比较字符串的第一个字符,如果它们不同,那么比较就基于这两个字符的ASCII值;如果相同,则继续比较下一个字符,直到找到不同的字符或者比较完所有字符。

对于’overlap’>'conflagration’这个比较:

比较第一个字符:‘o’(overlap的第一个字符)和’c’(conflagration的第一个字符)。在ASCII码表中,'o’的ASCII值大于’c’的ASCII值。

结果确定:由于第一个字符的比较就已经确定了结果,所以不需要继续比较后面的字符。

基于上述比较步骤,‘overlap’的第一个字符’o’在字典顺序上大于’conflagration’的第一个字符’c’,因此整个字符串’overlap’在字典顺序上也大于’conflagration’。

所以,‘overlap’>'conflagration’的结果是True。

3、假设要存放的数据元素是英文单词及含义。

(1)为了操作方便,定义命令符号、命令格式如下

在这里插入图片描述

(2)对命令进行提取key,value

示例

注意,输入的英文含义中如果含有逗号一定是中文逗号
在这里插入图片描述

(3)封装一个Elem()接口

要插入的每一个数据元素都是一个Elem()对象
在这里插入图片描述

4、插入函数

(1)图解

在这里插入图片描述

(2)代码

在这里插入图片描述

测试样例

在这里插入图片描述

测试结果(中序遍历)

在这里插入图片描述

(3)时间代价

不同的插入顺序会导致树形不同、尤其是树的高度不同

(1)顺序插入

在这里插入图片描述
逆序插入类似,都会导致二叉树不平衡,时间代价是O(n)

(2)打乱顺序插入

在这里插入图片描述
当树极度不平衡时,要插入元素若均大于树中元素,那么最坏情况将是O(n)

当树比较平衡时,要插入最大元素,最坏情况将是O(logn)

(4)假如没有封装的Elem()类

代码会比较冗余

代码

在这里插入图片描述

运行结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值