Java数据结构之 树(Tree)

Java数据结构之 树(Tree)


1. 二叉查找树(Binary Search Tree)

性质:

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

2)若右子树不为空,则右子树上所有节点的值均大于它的跟几点的值;

3)左右子树也分别为二叉查找树;

4)没有键值相同的节点(因此,插入的时候一定是叶子节点);

注: 插入有序节点时,退化成单支树;查找效率最好O(nlogn),最坏O(n);查找效率和插入效率相同(直插入叶子节点);删除效率最好O(logn)+O(1)->只有左子树或者只有右子树,删除效率最差O(logn)+O(logn)->左右子树同时存在;新插入的节点总是叶子节点!

2. 平衡二叉树

首先平衡二叉树是一棵二叉查找树,满足二叉查找树的所有性质。其次,它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是平衡二叉树。这个方案很好地解决了二叉查找树退化成链表的问题。这样把插入,查找,删除的时间控制在了O(logn)左右的时间。严格遵守平衡二叉树性质的是AVL树,平衡二叉树大部分操作与二叉查找树类似,主要不同在于插入删除的时候平衡二叉树的平衡可能被改变。

调整平衡:找出最小的不平衡二叉树(距离插入节点最近且左右子树高度相差大于1的节点作为根的子树),利用旋转重新调整平衡性。

3. 红黑树

红黑树也是一棵二叉查找树,并且是一棵平衡二叉树(弱平衡)。与AVL树不同,红黑树并不是严格遵守平衡二叉树的定义,在增加或者删除节点的时候,根据不同情况,AVL树旋转的次数比红黑树更多,所以红黑树用非严格的平衡来换取增删节点旋转次数的降低。

特点:在二叉查找树的基础上红黑树有如下属性

1)每个节点或者是黑色或者是红色;

2)根节点是黑色;

3)每个叶子节点是黑色(这里的叶子节点,指的是为空Null的叶子节点);

4)如果一个节点是红色的,那么他的子节点必须是黑色;

5)从一个节点到该节点的子孙外部节点的所有路径上包含相同数目的黑节点;

由性质5我们可以得知,红黑树最大路径长度不超过最短路径长度的2倍:

最长:根(黑)->红->黑->...黑(叶子节点) 红色穿插

最短:根(黑)->黑->黑->...黑(叶子节点) 全是黑色

  1. 查找代价:基本维持在O(logn)左右,但最差情况下(最长是最短的2倍)比AVL树略差;
  2. 插入代价:RBT插入需要旋转操作和变色操作。由于只需要保持RBT基本平衡,因此插入节点最多只需要旋转2次;
  3. 删除代价:RBT删除一个节点最多需要旋转3次,好于AVL树;

由于RBT不是高度平衡的,因此插入和删除操作改变树的平衡性的概率远小于AVL树

红黑树插入节点的操作流程:

  1. 将红黑树当做一棵二叉查找树,将节点插入;
  2. 将插入的节点着色为红色;
  3. 通过一系列旋转和着色操作,使之重新成为一棵红黑色树(核心思路就是将红色的节点向上移动到根节点,然后,将根节点设置为黑色);

4. B树

B树和B+树可以解决磁盘IO问题。每个磁盘页对应树的节点,平衡二叉树由于树的深度过大而造成磁盘IO读写过于频繁,导致效率不佳。为了减少磁盘IO的次数,必须降低树的深度。

  1. 每个节点存储多个元素;
  2. 摒弃二叉树结果,才用多叉树;

B树(多路查找树)-> 查找效率O(logn)
M阶B树的特性(最多一个节点可以有m个孩子):

1)根节点至少有两个孩子;

2)每个中间节点包含k-1个元素,指向k个孩子,ceil(m/2)<=k<=m;

  1. 每个叶子节点包含k-1个元素,其中ceil(m/2)<=k<=m;

4)所有叶子节点都位于同一层;

5)每个节点中元素从小到大排列,节点中k-1个元素正好是k个孩子所包含元素的值域划分;

B树中所有节点的孩子节点的最大个数为B树的阶。对高度为k的m阶B树进行插入,新节点一般插入在叶子层:1) 若该节点中的元素个数小于m-1,直接插入; 2)若该节点中的元素个数等于m-1,节点分裂,以中间元素为界节点一分为二,产生一个新节点,并把中间元素插入到父节点中;

5. B+树

B+树是B树的变种,有着比B树更高的查询效率,大体上两者类似,m阶B+树的特征:

1)有k个子树的中间节点包含有k个元素(B树中是k-1个),每个元素不保存数据(B树元素是保存数据的),只用来索引,所有数据保存于叶子节点;

2)所有的叶子节点中包含了全部元素的信息,以及指向含这些元素的指针,叶子节点本身依关键字的大小自小而大顺序链接;

3)所有的中间元素(中间节点元素)同时存在于子节点,在子节点元素中是最大(最小)的,B+树查询每次必须到达叶子节点,范围查询上,B+树有顶向下二分查找确定下限,再通过叶子节点的链表顺序遍历即可找到上限;

B+树比B树的优势:

  1. 单一节点存储更多的元素,查询IO次数更少;
  2. 所有查询都要到叶子节点,性能稳定;
  3. 所有叶子节点形成有顺序的链表;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352