精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試官問你B樹和B+樹,就把這篇文章丟給他

大數據
在介紹B+樹之前, 先簡單的介紹一下B樹,這兩種數據結構既有相似之處,也有他們的區(qū)別,最后,我們也會對比一下這兩種數據結構的區(qū)別。

1 B樹

在介紹B+樹之前, 先簡單的介紹一下B樹,這兩種數據結構既有相似之處,也有他們的區(qū)別,最后,我們也會對比一下這兩種數據結構的區(qū)別。

[[277235]]

1.1 B樹概念

B樹也稱B-樹,它是一顆多路平衡查找樹。二叉樹我想大家都不陌生,其實,B樹和后面講到的B+樹也是從最簡單的二叉樹變換而來的,并沒有什么神秘的地方,下面我們來看看B樹的定義。

  • 每個節(jié)點最多有m-1個關鍵字(可以存有的鍵值對)。
  • 根節(jié)點最少可以只有1個關鍵字。
  • 非根節(jié)點至少有m/2個關鍵字。
  • 每個節(jié)點中的關鍵字都按照從小到大的順序排列,每個關鍵字的左子樹中的所有關鍵字都小于它,而右子樹中的所有關鍵字都大于它。
  • 所有葉子節(jié)點都位于同一層,或者說根節(jié)點到每個葉子節(jié)點的長度都相同。
  • 每個節(jié)點都存有索引和數據,也就是對應的key和value。

所以,根節(jié)點的關鍵字數量范圍:1 <= k <= m-1,非根節(jié)點的關鍵字數量范圍:m/2 <= k <= m-1。

另外,我們需要注意一個概念,描述一顆B樹時需要指定它的階數,階數表示了一個節(jié)點最多有多少個孩子節(jié)點,一般用字母m表示階數。

我們再舉個例子來說明一下上面的概念,比如這里有一個5階的B樹,根節(jié)點數量范圍:1 <= k <= 4,非根節(jié)點數量范圍:2 <= k <= 4。

下面,我們通過一個插入的例子,講解一下B樹的插入過程,接著,再講解一下刪除關鍵字的過程。

1.2 B樹插入

插入的時候,我們需要記住一個規(guī)則:判斷當前結點key的個數是否小于等于m-1,如果滿足,直接插入即可,如果不滿足,將節(jié)點的中間的key將這個節(jié)點分為左右兩部分,中間的節(jié)點放到父節(jié)點中即可。

例子:在5階B樹中,結點最多有4個key,最少有2個key(注意:下面的節(jié)點統(tǒng)一用一個節(jié)點表示key和value)。

插入18,70,50,40

面試官問你B樹和B+樹,就把這篇文章丟給他

插入22

面試官問你B樹和B+樹,就把這篇文章丟給他

插入22時,發(fā)現這個節(jié)點的關鍵字已經大于4了,所以需要進行分裂,分裂的規(guī)則在上面已經講了,分裂之后,如下。

面試官問你B樹和B+樹,就把這篇文章丟給他

接著插入23,25,39

面試官問你B樹和B+樹,就把這篇文章丟給他

分裂,得到下面的。

面試官問你B樹和B+樹,就把這篇文章丟給他

更過的插入的過程就不多介紹了,相信有這個例子你已經知道怎么進行插入操作了。

1.3 B樹的刪除操作

B樹的刪除操作相對于插入操作是相對復雜一些的,但是,你知道記住幾種情況,一樣可以很輕松的掌握的。

現在有一個初始狀態(tài)是下面這樣的B樹,然后進行刪除操作。

面試官問你B樹和B+樹,就把這篇文章丟給他

刪除15,這種情況是刪除葉子節(jié)點的元素,如果刪除之后,節(jié)點數還是大于m/2,這種情況只要直接刪除即可。

面試官問你B樹和B+樹,就把這篇文章丟給他

面試官問你B樹和B+樹,就把這篇文章丟給他

接著,我們把22刪除,這種情況的規(guī)則:22是非葉子節(jié)點,對于非葉子節(jié)點的刪除,我們需要用后繼key(元素)覆蓋要刪除的key,然后在后繼key所在的子支中刪除該后繼key。對于刪除22,需要將后繼元素24移到被刪除的22所在的節(jié)點。

面試官問你B樹和B+樹,就把這篇文章丟給他

面試官問你B樹和B+樹,就把這篇文章丟給他

此時發(fā)現26所在的節(jié)點只有一個元素,小于2個(m/2),這個節(jié)點不符合要求,這時候的規(guī)則(向兄弟節(jié)點借元素):如果刪除葉子節(jié)點,如果刪除元素后元素個數少于(m/2),并且它的兄弟節(jié)點的元素大于(m/2),也就是說兄弟節(jié)點的元素比最少值m/2還多,將先將父節(jié)點的元素移到該節(jié)點,然后將兄弟節(jié)點的元素再移動到父節(jié)點。這樣就滿足要求了。

我們看看操作過程就更加明白了。

面試官問你B樹和B+樹,就把這篇文章丟給他

面試官問你B樹和B+樹,就把這篇文章丟給他

接著刪除28,刪除葉子節(jié)點,刪除后不滿足要求,所以,我們需要考慮向兄弟節(jié)點借元素,但是,兄弟節(jié)點也沒有多的節(jié)點(2個),借不了,怎么辦呢?如果遇到這種情況,首先,還是將先將父節(jié)點的元素移到該節(jié)點,然后,將當前節(jié)點及它的兄弟節(jié)點中的key合并,形成一個新的節(jié)點。

面試官問你B樹和B+樹,就把這篇文章丟給他

移動之后,跟兄弟節(jié)點合并。

面試官問你B樹和B+樹,就把這篇文章丟給他

刪除就只有上面的幾種情況,根據不同的情況進行刪除即可。

上面的這些介紹,相信對于B樹已經有一定的了解了,接下來的一部分,我們接著講解B+樹,我相信加上B+樹的對比,就更加清晰明了了。

2 B+樹

2.1 B+樹概述

B+樹其實和B樹是非常相似的,我們首先看看相同點。

  • 根節(jié)點至少一個元素
  • 非根節(jié)點元素范圍:m/2 <= k <= m-1

不同點。

  • B+樹有兩種類型的節(jié)點:內部結點(也稱索引結點)和葉子結點。內部節(jié)點就是非葉子節(jié)點,內部節(jié)點不存儲數據,只存儲索引,數據都存儲在葉子節(jié)點。
  • 內部結點中的key都按照從小到大的順序排列,對于內部結點中的一個key,左樹中的所有key都小于它,右子樹中的key都大于等于它。葉子結點中的記錄也按照key的大小排列。
  • 每個葉子結點都存有相鄰葉子結點的指針,葉子結點本身依關鍵字的大小自小而大順序鏈接。
  • 父節(jié)點存有右孩子的第一個元素的索引。

下面我們看一個B+樹的例子,感受感受它吧!

面試官問你B樹和B+樹,就把這篇文章丟給他

2.2 插入操作

對于插入操作很簡單,只需要記住一個技巧即可:當節(jié)點元素數量大于m-1的時候,按中間元素分裂成左右兩部分,中間元素分裂到父節(jié)點當做索引存儲,但是,本身中間元素還是分裂右邊這一部分的。

下面以一顆5階B+樹的插入過程為例,5階B+樹的節(jié)點最少2個元素,最多4個元素。

插入5,10,15,20

面試官問你B樹和B+樹,就把這篇文章丟給他

插入25,此時元素數量大于4個了,分裂

面試官問你B樹和B+樹,就把這篇文章丟給他

接著插入26,30,繼續(xù)分裂

面試官問你B樹和B+樹,就把這篇文章丟給他

面試官問你B樹和B+樹,就把這篇文章丟給他

有了這幾個例子,相信插入操作沒什么問題了,下面接著看看刪除操作。

2.3 刪除操作

對于刪除操作是比B樹簡單一些的,因為葉子節(jié)點有指針的存在,向兄弟節(jié)點借元素時,不需要通過父節(jié)點了,而是可以直接通過兄弟節(jié)移動即可(前提是兄弟節(jié)點的元素大于m/2),然后更新父節(jié)點的索引;如果兄弟節(jié)點的元素不大于m/2(兄弟節(jié)點也沒有多余的元素),則將當前節(jié)點和兄弟節(jié)點合并,并且刪除父節(jié)點中的key,下面我們看看具體的實例。

初始狀態(tài)

面試官問你B樹和B+樹,就把這篇文章丟給他

刪除10,刪除后,不滿足要求,發(fā)現左邊兄弟節(jié)點有多余的元素,所以去借元素,最后,修改父節(jié)點索引

面試官問你B樹和B+樹,就把這篇文章丟給他

刪除元素5,發(fā)現不滿足要求,并且發(fā)現左右兄弟節(jié)點都沒有多余的元素,所以,可以選擇和兄弟節(jié)點合并,最后修改父節(jié)點索引

面試官問你B樹和B+樹,就把這篇文章丟給他

發(fā)現父節(jié)點索引也不滿足條件,所以,需要做跟上面一步一樣的操作

面試官問你B樹和B+樹,就把這篇文章丟給他

這樣,B+樹的刪除操作也就完成了,是不是看完之后,覺得非常簡單!

3 B樹和B+樹總結

B+樹相對于B樹有一些自己的優(yōu)勢,可以歸結為下面幾點。

  • 單一節(jié)點存儲的元素更多,使得查詢的IO次數更少,所以也就使得它更適合做為數據庫MySQL的底層數據結構了。
  • 所有的查詢都要查找到葉子節(jié)點,查詢性能是穩(wěn)定的,而B樹,每個節(jié)點都可以查找到數據,所以不穩(wěn)定。
  • 所有的葉子節(jié)點形成了一個有序鏈表,更加便于查找。

 

 

責任編輯:未麗燕 來源: SegmentFault.com
相關推薦

2020-04-20 13:11:21

HashMap底層存儲

2019-11-04 15:00:50

MySQL索引B+樹

2019-11-05 14:06:07

MySQLB+索引

2022-09-26 10:09:08

MVCC控制并發(fā)

2018-08-07 16:01:32

synchronizevolatilefinal

2021-02-22 13:32:19

MySQLSQL索引

2025-11-03 16:30:44

2020-09-08 06:43:53

B+樹面試索引

2025-09-17 07:56:32

2022-11-08 09:33:36

訂單系統(tǒng)電商

2020-12-11 08:23:06

JavaMemory Mode內存模型

2018-07-03 14:54:25

Java內存模型

2018-12-07 09:31:52

分布式鎖服務框架分布式系統(tǒng)

2021-06-02 10:23:06

索引B+樹數據

2019-04-15 14:40:46

消息隊列Java編程

2019-08-29 10:46:22

MySQL索引數據庫

2020-04-01 18:08:57

MySQL B-樹B+樹

2021-05-31 09:42:48

MySQL隔離級別

2021-07-04 15:16:14

索引B+數據庫

2019-12-10 09:08:29

分布式開源RocketMQ
點贊
收藏

51CTO技術棧公眾號

91麻豆精品国产91久久久更新资源速度超快 | 欧美2区3区4区| 亚洲综合一二三区| 免费看污久久久| 国产免费叼嘿网站免费| 亚洲影院一区| 久久久精品免费| 艳妇乳肉亭妇荡乳av| 亚洲国产伊人| 欧美日韩中文字幕| 一区二区三区四区免费观看| 亚洲熟女乱综合一区二区| 国产精品熟女视频| 911精品美国片911久久久| 亚洲激情小视频| av中文字幕网址| sm久久捆绑调教精品一区| 中文字幕巨乱亚洲| 精品国产一区二区三| 国产免费叼嘿网站免费| 日本特黄久久久高潮| 久久久久久国产精品美女| 国产三级精品三级观看| 久久365资源| 亚洲欧美日韩中文播放 | 成人中文字幕在线播放| 一区二区高清不卡| av一区二区三区四区| 成人免费网视频| 日本中文字幕在线观看视频| 99成人免费视频| 久久av中文字幕| 亚洲精品国产精品国自| 一区二区导航| 日韩大片在线观看视频| 欧美图片自拍偷拍| 精品入口麻豆88视频| 欧美人狂配大交3d怪物一区 | 午夜影院在线观看国产主播| 一区二区三区四区精品在线视频| 五月天色一区| 国产资源在线播放| 久久女同精品一区二区| 久精品国产欧美| 天天av天天翘| 99麻豆久久久国产精品免费优播| 国产精品对白刺激久久久| 99免费在线视频| 国产呦精品一区二区三区网站 | 九九热精品免费视频| 日韩精品一区二区三区中文在线 | 任你操这里只有精品| 成人一级福利| 婷婷中文字幕综合| 欧美精品久久久久久久自慰| 超黄网站在线观看| 亚洲成av人影院| av日韩一区二区三区| 国产91足控脚交在线观看| 一区二区三区欧美| 免费在线看黄色片| av资源在线| 欧美日韩国产精品专区| 日本一区二区黄色| 日韩一级二级| 精品久久久久国产| 国产欧美日本| 国模一区二区三区| 久久精品国产精品亚洲| 久久精品国产亚洲av麻豆| 国产福利资源在线| 国内精品国产成人| 亚洲最大福利网| 亚洲精品综合久久| 美女视频亚洲色图| 日韩精品高清在线观看| 全黄一级裸体片| 精品毛片免费观看| 久久在精品线影院精品国产| 国产波霸爆乳一区二区| 好看的日韩av电影| 青青草精品毛片| 91激情在线观看| 成人蜜臀av电影| 欧美日韩一区二 | 中文字幕无线精品亚洲乱码一区| 综合 欧美 亚洲日本| 欧美三级特黄| 国产成人精品免高潮费视频| 亚洲黄色成人久久久| 亚洲精品综合网| 久久精品人人做人人综合| 日韩在线三区| 黄网av在线| 在线精品视频一区二区三四 | 国产成人免费在线观看| 久久亚洲国产精品日日av夜夜| 高清国产福利在线观看| 有码一区二区三区| 国产第一页视频| 国产视频一区二区在线播放| 日韩av一区在线观看| 制服丨自拍丨欧美丨动漫丨| 精品1区2区3区4区| 国产精品视频导航| 亚洲aaa在线观看| 亚洲精品欧美在线| 欧美日韩在线免费播放| 91精品导航| 日日噜噜噜夜夜爽亚洲精品| 久久狠狠高潮亚洲精品| 国内精品伊人久久久久av一坑 | 不卡一区2区| 日韩美女一区二区三区| 久久久久久久久久久久| 午夜天堂精品久久久久| 国产精品狠色婷| 国产成人手机在线| 亚洲同性gay激情无套| 可以在线看的黄色网址| 久久久精品麻豆| 亚洲va电影大全| 国产日韩欧美久久| 国内精品麻豆美女在线播放视频| 中文综合在线观看| 91热视频在线观看| 免费一级全黄少妇性色生活片| 亚洲色图插插| 国产成人在线亚洲欧美| 天堂av在线免费观看| 国产精品国产成人国产三级| 亚洲激情久久| 九九**精品视频免费播放| 成人国产在线视频| 国产在线观看免费网站| 亚洲第一av色| 国产精九九网站漫画| 91精品天堂福利在线观看| 国产精品爽爽爽| 国产一区二区三区福利| 色综合视频一区二区三区高清| 国产a级黄色片| 国产精品theporn| 91久久精品国产91久久性色tv| 色哟哟免费在线观看| 欧美天天综合网| 久久精品免费一区二区| 嗯用力啊快一点好舒服小柔久久| 久久国产精品免费视频| hs视频在线观看| 一区二区三区四区视频精品免费 | 日本精品一区二区三区视频| 新版的欧美在线视频| 亚洲精品成人久久电影| 欧美成人精品欧美一级乱黄| caoporm超碰国产精品| 美女扒开大腿让男人桶| 欧美午夜寂寞| 日韩免费在线播放| www.亚洲资源| 欧美久久久久久蜜桃| 黑人巨大精品一区二区在线| 高清不卡在线观看av| 日韩欧美不卡在线| 亚洲系列另类av| 国产狼人综合免费视频| 日本在线免费中文字幕| 欧美一区二区私人影院日本| 国产亚洲精品久久久久久打不开| 成人福利在线看| 国产成人精品无码播放| 日韩精品一区二区久久| 91久久精品久久国产性色也91| 里番在线播放| 亚洲精品之草原avav久久| 在线免费一区二区| 亚洲女人小视频在线观看| 男人的天堂影院| av片在线观看| 一级特黄大欧美久久久| 黄色性生活一级片| 蜜桃av一区二区在线观看| 最新黄色av网站| 神马香蕉久久| 91久久精品国产91久久| 97天天综合网| 中文日韩在线视频| 亚洲高清视频在线播放| 色婷婷激情久久| 黑鬼狂亚洲人videos| 91在线视频18| 久久6免费视频| 6699嫩草久久久精品影院| 青青草伊人久久| 成年人免费观看的视频| 另类在线视频| 国产区亚洲区欧美区| 1024在线看片你懂得| 色偷偷av一区二区三区乱| 刘玥91精选国产在线观看| 在线观看网站黄不卡| 欧美精品入口蜜桃| 欧美激情一区二区三区在线| 在线播放第一页| 美国十次了思思久久精品导航| 婷婷五月综合缴情在线视频| 日韩在线不卡| 久久久精彩视频| 韩国一区二区三区视频| 国产成人avxxxxx在线看| av在线网址观看| 在线成人中文字幕| 手机av免费在线观看| 91麻豆精品国产91久久久资源速度 | 国精一区二区| 国产精品嫩草在线观看| 久久国产精品美女| 国产精品久久一区主播| 美女18一级毛片一品久道久久综合| 久久国产精品99国产精| 日本中文字幕视频在线| 国产亚洲精品美女久久久| 婷婷丁香一区二区三区| 日韩欧美另类在线| 91资源在线视频| 在线观看日韩高清av| 毛片毛片女人毛片毛片| 亚洲国产一二三| 免费在线视频一区二区| 亚洲免费观看在线视频| 国产传媒免费在线观看| 欧美激情资源网| 欧洲女同同性吃奶| 91网上在线视频| 国产老熟女伦老熟妇露脸| 国产不卡高清在线观看视频| 18深夜在线观看免费视频| 狠狠色丁香九九婷婷综合五月| 亚洲三级视频网站| 美女免费视频一区二区| 中文字幕第36页| 毛片av一区二区| 亚洲欧美自拍另类日韩| 久久精品国产第一区二区三区| 精品久久久噜噜噜噜久久图片| 老司机午夜精品视频在线观看| 中国丰满人妻videoshd| 久久久久久亚洲精品杨幂换脸| 茄子视频成人免费观看| 久久精品首页| 一级黄色香蕉视频| 久久99九九99精品| 亚洲天堂网站在线| 国产成人亚洲精品青草天美| 91精产国品一二三| 成人亚洲精品久久久久软件| 亚洲日本久久久| 99在线精品视频| 中文字幕在线看高清电影| 日本一区二区三区国色天香| 欧美成人久久久免费播放| 国产精品国产三级国产普通话蜜臀 | 狠狠躁夜夜躁人人躁婷婷91| 五月天激情四射| 欧美视频日韩视频在线观看| 一卡二卡在线视频| 日韩视频在线你懂得| 熟妇人妻av无码一区二区三区| 亚洲精品久久久久久下一站| 国产青青草在线| 久久香蕉频线观| www中文字幕在线观看| 欧美综合第一页| 农村妇女一区二区| 成人三级在线| 性欧美lx╳lx╳| 一区二区精品在线观看| 午夜国产欧美理论在线播放 | 亚洲ai欧洲av| 欧美日韩1区| 激情六月丁香婷婷| 激情亚洲综合在线| 国产免费一区二区三区最新6| 久久天天做天天爱综合色| 成人一级黄色大片| 亚洲r级在线视频| 制服丝袜在线一区| 精品国产亚洲在线| 国产大学生校花援交在线播放| 久久亚洲春色中文字幕| 天天综合av| 亚洲一区二区在线| 免费成人高清在线视频theav| 亚洲一区二区免费视频软件合集 | 亚洲欧美国产高清va在线播放| 亚洲男人7777| 日本电影在线观看| 国产精品丝袜久久久久久高清| 91精品国产自产在线丝袜啪| 日韩中文字幕av在线| 亚洲性图久久| 亚洲一区日韩精品| 91免费观看视频| 激情综合网五月天| 欧美日韩精品是欧美日韩精品| 人妻夜夜爽天天爽| 欧美中文字幕不卡| 亚洲国产福利视频| 最新的欧美黄色| 一区二区三区电影大全| 99在线观看视频| 欧美肥老太太性生活| av动漫在线观看| 成人性视频免费网站| 日韩三级在线观看视频| 欧美三级视频在线| 牛牛澡牛牛爽一区二区| 欧美高清在线观看| 电影中文字幕一区二区| 色综合视频二区偷拍在线| 99热精品在线| 无码人妻丰满熟妇啪啪网站| 亚洲免费伊人电影| 一级特黄aaa大片| 中文字幕一区二区精品| 91精品国产经典在线观看| 欧美福利精品| 99精品国产在热久久| 亚洲精品久久一区二区三区777 | 99久久伊人久久99| 国产精品成人久久| 日韩欧美国产一区在线观看| 黄网站app在线观看| 国产精品入口免费视频一| 狠狠做六月爱婷婷综合aⅴ| 青青草原成人网| xnxx国产精品| 岛国av中文字幕| 亚洲日韩第一页| 亚洲天堂一区二区| 农村寡妇一区二区三区| 美女91精品| 国产人妻大战黑人20p| 欧洲精品视频在线观看| 国产毛片在线看| 国产精品影片在线观看 | 久久久久久久9| 丰满放荡岳乱妇91ww| 国产一级久久久| 亚洲福利在线播放| 男人av在线播放| 欧美性大战久久久久| 日本不卡一二三区黄网| 国产精品免费无码| 欧美日韩亚州综合| 看黄网站在线| 999在线观看免费大全电视剧| 欧美日韩视频| asian性开放少妇pics| 色综合一区二区| 在线免费观看黄色网址| 亚洲aⅴ男人的天堂在线观看| 欧美视频四区| 精品黑人一区二区三区观看时间| 狠狠久久亚洲欧美专区| 1024视频在线| 91网免费观看| 在线一区欧美| 日本高清黄色片| 日韩一区二区三区视频在线| 91破解版在线观看| 色一情一乱一伦一区二区三区丨| 经典三级在线一区| 国产真实夫妇交换视频| 国产视频一区在线| 婷婷激情成人| 日本福利视频一区| 久久精品网站免费观看| 亚洲天天综合网| 欧美第一淫aaasss性| 色综合综合网| 亚洲网中文字幕| 色综合天天综合网天天狠天天 | 免费a级片在线观看| 日本老师69xxx| 伊人成综合网| 亚洲自拍偷拍一区二区| 欧美乱妇20p| 欧产日产国产精品视频| 在线观看日本一区| 99这里只有精品| 97精品人妻一区二区三区在线| 午夜精品久久久久久99热| 欧美一区二区性| 国产免费a级片| 欧美日韩精品综合在线| 乡村艳史在线观看| 国产精品av免费观看| 久久精品一区二区| 亚洲精品97久久中文字幕无码 |