计算机系统的详细结构树,数据结构中的各种树浅谈

lgbbor8wg1.jpeg

树{树的基本概念(结点(结点的度)、层次、深度(高)、有序树与无序树、森林)、树的存储结构(双亲表示法、孩子表示法、孩子兄弟表示法)、二叉树(二叉树的类型(特殊二叉树、满二叉树、完全二叉树)、二叉树的存储结构、二叉树的遍历(前序遍历、中序遍历、后序遍历、层序遍历)、二叉树的建立(树、森林、二叉树的转换、赫夫曼树、赫夫曼编码(压缩算法))、查找二叉树、(平衡树、红黑树))}。set和map容器都有基于哈希存储和排序树的两种实现版本,基于哈希存储的版本理论存取时间复杂度为o(1),而基于排序树版本的实现在插入或删除元素时会按照元素或元素的键(key)构成排序树从而达到排序和去重的效果。8 查找结构:符号表,二叉查找树,二叉查找树的查找、插入和删除操作,avl树,高度平衡,ll, lr, rr, rl 旋转, 插入算法,时间复杂性分析,b树

1、二叉查找树(二叉排序树)

0a5ba68ba0c430ffb5ecfaa04c3e1eb8.png(图a)

二叉查找树是一种动态查找表(图a),具有这些性质:

(1)若它的左子树不为空,则左子树上的所有节点的值都小于它的根节点的值;

(2)若它的右子树不为空,则右子树上所有节点的值都大于它的根节点的值;

(3)其他的左右子树也分别为二叉查找树;

8 查找结构:符号表,二叉查找树,二叉查找树的查找、插入和删除操作,avl树,高度平衡,ll, lr, rr, rl 旋转, 插入算法,时间复杂性分析,b树,m叉查找树,m叉查找树的查找,b树的定义和性质,b树的插入操作,b树的删除操作,静态散列,散列表,散列函数,溢出处理,开放寻址,链接。c++ stl(standard template library标准模板库)是通用类模板和算法的集合,它提供给程序员一些标准的数据结构的实现如queues(队列),lists(链表),和stacks(栈)等.c++stl提供给程序员以下三类数据结构的实现:标准容器类顺序性容器vector从后面快速的插入与删除,直接访问任何元素deque从前面或后面快速的插入与删除,直接访问任何元素list双链表,从任何地方快速插入与删除关联容器set快速查找,不允许重复值multiset快速查找,允许重复值map一对多映射,基于关键字快速查找,不允许重复值multimap一对多映射,基于关键字快速查找,允...。根据平衡二叉树的启发,自然就想到平衡多路查找树结构,也就是这篇文章所要阐述的第一个主题b~tree,即b树结构(后面,我们将看到,b树的各种操作能使b树保持较低的高度,从而达到有效避免磁盘过于频繁的查找存取操作,从而有效提高查找效率)。

2、平衡二叉树(AVL树)

22a7112e73b57a88917583b89b876f00.png(图b)

为了加快col2的查找,可以维护一个右边所示的二叉查找树,每个节点分别包含索引键值和一个指向对应数据记录物理地址的指针,这样就可以运用二叉查找在o(log2n)的复杂度内获取到相应数据。对要回收的region(或合并后的region),继续查找当前树是否有一个region节点,其end和要回收的(或已合并的)region的(start - 1)的值相等,如果有,则删除树中的原节点并返回,合并这两个节点,将合并后的节点继续插入树中。8 查找结构:符号表,二叉查找树,二叉查找树的查找、插入和删除操作,avl树,高度平衡,ll, lr, rr, rl 旋转, 插入算法,时间复杂性分析,b树,m叉查找树,m叉查找树的查找,b树的定义和性质,b树的插入操作,b树的删除操作,静态散列,散列表,散列函数,溢出处理,开放寻址二叉排序树 数据结构,链接。

(1)要么是棵空树,要么其根节点左右子树的深度之差的绝对值不超过1;

a21901acfea24d24494b4b2c2e020a43.png

(2)其左右子树也都是平衡二叉树;

这就是一颗二叉树,假设binarytree[i]是二叉树的一个节点,那么它的左孩子节点 leftchild = binarytree[i*2+1]那么相应的右孩子节点 rightchild = binarytree[i*2+2]。二叉树的链式存储:将二叉树的节点定义为一个对象,节点之间通过类似链表的链接方式来链接。一个很简单的解释是:如果将b的左子节点d拿到a的左子节点,那么b右旋后右子节点指向a,b原来的右子节点e就成为了一个游离的节点,游离于整个数据结构之外。

3、红黑树

a3f479adf0dbc10f647564a4ae00fed8.png(图c)

红黑树是一种自平衡二叉树,在平衡二叉树的基础上每个节点又增加了一个颜色的属性,节点的颜色只能是红色或黑色。具有以下性质:

(1)根节点只能是黑色;

(2)红黑树中所有的叶子节点后面再接上左右两个空节点,这样可以保持算法的一致性,而且所有的空节点都是黑色;

(3)其他的节点要么是红色,要么是黑色,红色节点的父节点和左右孩子节点都是黑色,及黑红相间;

从树中的一个节点到另一个节点之间的分支构成两个点之间的路径,路径上的分支数目称作路径长度。因为原来那个要调整的节点为黑色,它一旦被删除就路径上的黑色节点少了1.所以这里a所在的路径都是黑色节点少1.这里将a的兄弟节点变成红色后,从它的父节点到下面的所有路径就都统一少了1.保证最后又都平衡了。磁盘io次数,b-树(b类树)的特定就是每层节点数目非常多,层数很少,目的就是为了就少磁盘io次数,当查询数据的时候,最好的情况就是很快找到目标索引,然后读取数据,使用b+树就能很好的完成这个目的,但是b-树的每个节点都有data域(指针),这无疑增大了节点大小,说白了增加了磁盘io次数(磁盘io一次读出的数据量大小是固定的,单个数据变大,每次读出的就少,io次数增多,一次io多耗时啊。

4、B-树

310c0518506fb68d25d9d2c8533f0beb.png(图d)

B-树是一种平衡多路查找树,它在文件系统中很有用。一棵m阶B-树(图d为4阶B-树),具有下列性质:

804fc2eff9f516b430d268128e7ff311.png

(1)树中每个节点至多有m棵子树;

(2)若根节点不是叶子节点,则至少有2棵子树;

(3)除根节点之外的所有非终端节点至少有

2f5bfce1158f41d28a076d49d8890d3f.png棵子树;

(4)每个节点中的信息结构为(A0,K1,A1,K2......Kn,An),其中n表示关键字个数,Ki为关键字,Ai为指针;

(5)所有的叶子节点都出现在同一层次上,且不带任何信息,也是为了保持算法的一致性。

5、B+树

67cebe2aed7bbe6744ce9fe792802d37.png(图e)

B+数是B-树的一种变形,它与B-树的差别在于(图e为3阶B+树):

(1)有n棵子树的节点含有n个关键字;

(2)所有的叶子节点包含了全部关键字的信息,及指向这些关键字记录的指针,且叶子节点本身按关键字大小自小到大顺序链接;

(3)所有非终端节点可以看成是索引部分,节点中仅含有其子树(根节点)中最大(或最小)关键字,所有B+树更像一个索引顺序表;

(4)对B+树进行查找运算,一是从最小关键字起进行顺序查找,二是从根节点开始,进行随机查找。

d5a87c54e7935cb3cc55711b3f4a45d1.png

6、字典树(trie树)

977121135421b9a61f3bce9909925507.png(图f)

innodb 字典信息缓存(innodb additional memory pool):innodb 字典信息缓存主要用来存放 innodb 存储引擎的字典信息以及一些 internal 的共享数据结构信息。vim使用通用的表达式(regular expressions)来进行逻辑查找.我们在以前讨论过用简单的字符串进行查找,但是这里我们将要看到的通用字符串查找要简单字符查找的功能强大得多.通过在我们的命令中使用通用表达式,我们可以查找任何一种字符类型,例如我们可以查找以t开头而以ing结尾的字尾串(通用表达式为\).然而这种强大的功能也是要付出一定的代价的.通用表达式是神秘的和简洁的.也许我们要花上很上的一段时间才会习惯这种查找方式,然后才能掌握这个强大的查找工具.。首先粗分,依照句子把文本切成一个一个句子,然后把每个句子切成单字,字典依照树形构造存储,比方这句话“春天还会远吗”首先查找“春”字扫尾的词,然后依照字典树形构造往下走一个节点,查找“春”前面一个字是“天”的词,然后又下沉一个节点,找“还”上面是“会”的词,找不到了,查找就完毕。

(1)根节点为空;

(2)除根节点外,每个节点包含一个字符;

(3)从根节点到某一节点,路径上经过的字符连接起来,为该节点对应的字符串。

(4)每个字符串在建立字典树的过程中都要加上一个区分的结束符,避免某个短字符串正好是某个长字符串的前缀而淹没。

7、后缀树

faller等人提出了动态哈夫曼编码方法,它对数据编码的依据是动态变化的哈夫曼树,也就是说,对第t+1个字符编码是根据原始数据中前t个字符得到的哈夫曼树来进行的.压缩和解压子程序具有相同的初始化树,每处理完一个字符,压缩和解压方使用相同的算法修改哈夫曼树,因而该方法不需要为解压而保存树的有关信息。findstr 寻找短串的起始字符下标。利用scanf函数从键盘接收一字符(或整数)时,它只读入字符(或整数)本身,而把字符(或整数)后的回车符留在输入缓冲区内。

S[1..8], XMADAMYX, 也就是字符串本身,起始位置为1

S[2..8], MADAMYX,起始位置为2

S[3..8], ADAMYX,起始位置为3

1f66b6a8639468567ec234e4cfab5bc2.png

S[4..8], DAMYX,起始位置为4

S[5..8], AMYX,起始位置为5

S[6..8], MYX,起始位置为6

S[7..8], YX,起始位置为7

S[8..8], X,起始位置为8

空字串。记为$。

所有这些后缀字符串组成一棵字典树:

suffix_trie633939784429401250.png

仔细观察上图,我们可以看到不少值得压缩的地方。比如蓝框标注的分支都是独苗,没有必要用单独的节点同边表示。如果我们允许任意一条边里包含多个字母,就可以把这种没有分叉的路径压缩到一条边。另外每条边已经包含了足够的后缀信息,我们就不用再给节点标注字符串信息了。我们只需要在叶节点上标注上每项后缀的起始位置。于是我们得到下图:

suffix_trie2633939784430026250.gif

这样的结构丢失了某些后缀。比如后缀X在上图中消失了,因为它正好是字符串XMADAMYX的前缀。为了避免这种情况,我们也规定每项后缀不能是其它后缀的前缀。要解决这个问题其实挺简单,在待处理的子串后加一个空字串就行了。例如我们处理XMADAMYX前,先把XMADAMYX变为 XMADAMYX$,于是就得到suffix tree。

suffix_tree3.png

这就形成一棵后缀树了。关于如何建立一棵后缀树,已有很成熟的算法,能在o(n)时间内解决。

8、广义后缀树

广义后缀树是好几个字符串的的所有后缀组成的字典树,同样每个字符串的所有后缀都具有一个相同的结束符,不同字符串的结束符不同。

目前字符型液晶显示模块已经是单片机应用设计中最常用的信息显示期间,lcd1602 液晶显示模块可以显示两行,每行16 个字符,其字符发生器rom 中自带数字和英文字母及一些特殊符号的字符库,没有汉字。注意:此时需用map容器定义一个变量rank,存储后缀字符在串s中开始的位置,。一个通用表达式是由一些元素组成的.这些元素是通用表达式中最小的匹配单位.一个元素可以是一个字符,例如a,与字符a相匹配,或者是一个特殊字符,例如$,匹配一行的结束.还可以是其他的字符,例如\来匹配一个单词的结束.也就是说要将我们想要查找的字符串放在这两个中间.这样我们就可以精确的来查找我们想要查找的字符串,而不会有其他的一些匹配情况.而如果我们用简单字符串形式来查找,我们就会得到许多的匹配情况,甚至在一个单词中的组成部分也可以成为匹配情况.例如在文件中有californian,unfortunately.如果用命令/for来查找,那么就会找到这两个单词.而如果我们用通用表达式\来进行查找,则只会精确的查找到for,而不会用其他的匹配情况.这时的命令形式如下:。

本文来自电脑杂谈,转载请注明本文网址:

http://www.pc-fly.com/a/jisuanjixue/article-107067-1.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值