<數(shù)據(jù)結(jié)構(gòu)>筆記1-【B樹和索引】

一、二叉排序樹(二叉查找樹)

空樹或具有下列性質(zhì)的二叉樹
1.左子樹所有節(jié)點(diǎn)值小于根節(jié)點(diǎn)
2.右子樹所有節(jié)點(diǎn)大于根節(jié)點(diǎn)
3.它的左右子樹分別為二叉排序樹

二亦鳞、平衡二叉樹(AVL樹)

  • 滿足二叉排序樹
  • 左右子樹高度相差不超過1

三、B-樹

  • 平衡
  • 多路排序樹
  • 主要用于文件索引


    B-樹

1. 特性:

1)所有非終端節(jié)點(diǎn)包含以下信息(key-value paris)

(n康谆,A0描扯,K1,A1迅耘,K2贱枣,A2...Kn,An) **
Ki--關(guān)鍵字
Ai--指向子樹根節(jié)點(diǎn)指針
n--關(guān)鍵字個(gè)數(shù)

2)所有葉節(jié)點(diǎn)出現(xiàn)在同一層颤专,包含關(guān)鍵字 或 指向關(guān)鍵字記錄的指針

關(guān)鍵字記錄纽哥?

關(guān)鍵字key為記錄的主鍵,只是記錄的一部分栖秕。

wikipedia for B-tree

The term leaf is also inconsistent.
Bayer & McCreight (1972) considered the leaf level to be the lowest level of keys, but Knuth considered the leaf level to be one level below the lowest keys (Folk & Zoellick 1992, p. 363).
There are many possible implementation choices.
In some designs, the leaves may hold the entire data record;
in other designs, the leaves may only hold pointers to the data record. Those choices are not fundamental to the idea of a B-tree.[5]

《數(shù)據(jù)結(jié)構(gòu)》嚴(yán)蔚敏版 此處有誤

3)樹中每個(gè)節(jié)點(diǎn)保存值

B-trees keep values in every node in the tree, and may use the same structure for all nodes.

2. B-樹查找分析

通常存儲(chǔ)在磁盤

兩步操作:

1) 找節(jié)點(diǎn)(磁盤)

磁盤隨機(jī)找到p所指節(jié)點(diǎn)春塌,并將節(jié)點(diǎn)信息讀入內(nèi)存

2) 節(jié)點(diǎn)中找關(guān)鍵字(內(nèi)存)

順序查找或折半查找關(guān)鍵字

四、B+樹

A B+ tree can be viewed as a B-tree in which each node contains only keys (not key–value pairs), and to which an additional level is added at the bottom with linked leaves.

note

12..34..567 are leaves,d1~d7 are not——they are data record.

A simple B+ tree example linking the keys 1–7 to data values d1-d7
A simple B+ tree example linking the keys 1–7 to data values d1-d7

與B-樹不同點(diǎn):

1. 所有葉子節(jié)點(diǎn)

1). 包含 全部關(guān)鍵字
2). 包含關(guān)鍵字記錄指針簇捍,如上圖12..34..567
3). 葉子節(jié)點(diǎn)升序順序鏈表鏈接

@Wikipedia-Btree

2. 非終端節(jié)點(diǎn)(即索引)只含關(guān)鍵字只壳,非B樹的關(guān)鍵字-指針對(duì)
3. 其他
  • n棵子樹含n個(gè)關(guān)鍵字
  • 兩指針與查找:
  • root節(jié)點(diǎn)指針-->隨機(jī)查找(必須,搜索總是從root節(jié)點(diǎn)開始暑塑,代替全表掃描)
  • 最小關(guān)鍵字葉子節(jié)點(diǎn)指針-->順序查找

五吼句、文件

1. 記錄2種結(jié)構(gòu)

邏輯結(jié)構(gòu)和物理結(jié)構(gòu)


2. 文件3種檢索方式

順序檢索

存取下一個(gè)邏輯記錄

直接檢索

存取第i個(gè)邏輯記錄

關(guān)鍵字檢索

查詢與關(guān)鍵字相關(guān)記錄

六、 索引文件

1. 索引表

記錄邏輯記錄物理記錄對(duì)應(yīng)關(guān)系

索引項(xiàng)
  • 定義:索引表中的項(xiàng)
  • 索引項(xiàng)關(guān)鍵字或邏輯記錄號(hào)排序

2. 索引文件

索引文件只能是==磁盤文件==

1)定義:

文件數(shù)據(jù)區(qū)+索引表

2)分類:

索引順序文件--數(shù)據(jù)區(qū)有序
索引非順序文件--數(shù)據(jù)區(qū)無序

3)索引文件檢索

兩步驟:

  1. 索引表(折半)
  2. 查記錄(依據(jù)索引項(xiàng))
  • 數(shù)據(jù)小--索引表在內(nèi)存事格,記錄在外存
  • 數(shù)據(jù)大--索引惕艳、記錄均在外存
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市分蓖,隨后出現(xiàn)的幾起案子尔艇,更是在濱河造成了極大的恐慌尔许,老刑警劉巖么鹤,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異味廊,居然都是意外死亡蒸甜,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門余佛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來柠新,“玉大人,你說我怎么就攤上這事辉巡『拊鳎” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵郊楣,是天一觀的道長(zhǎng)憔恳。 經(jīng)常有香客問我,道長(zhǎng)净蚤,這世上最難降的妖魔是什么钥组? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮今瀑,結(jié)果婚禮上程梦,老公的妹妹穿的比我還像新娘点把。我一直安慰自己,他們只是感情好屿附,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布郎逃。 她就那樣靜靜地躺著,像睡著了一般挺份。 火紅的嫁衣襯著肌膚如雪衣厘。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天压恒,我揣著相機(jī)與錄音影暴,去河邊找鬼。 笑死探赫,一個(gè)胖子當(dāng)著我的面吹牛型宙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播伦吠,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼妆兑,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了毛仪?” 一聲冷哼從身側(cè)響起搁嗓,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎箱靴,沒想到半個(gè)月后腺逛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡衡怀,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年棍矛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抛杨。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡够委,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出怖现,到底是詐尸還是另有隱情茁帽,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布屈嗤,位于F島的核電站潘拨,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏恢共。R本人自食惡果不足惜战秋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望讨韭。 院中可真熱鬧脂信,春花似錦癣蟋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至埋泵,卻和暖如春幔欧,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背丽声。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工礁蔗, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人雁社。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓浴井,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親霉撵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子磺浙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容

  • B樹的定義 一棵m階的B樹滿足下列條件: 樹中每個(gè)結(jié)點(diǎn)至多有m個(gè)孩子。 除根結(jié)點(diǎn)和葉子結(jié)點(diǎn)外徒坡,其它每個(gè)結(jié)點(diǎn)至少有m...
    文檔隨手記閱讀 13,240評(píng)論 0 25
  • B樹 1.前言: 動(dòng)態(tài)查找樹主要有:二叉查找樹(Binary Search Tree)撕氧,平衡二叉查找樹(Balan...
    鐵甲依然在_978f閱讀 1,447評(píng)論 0 4
  • 原文鏈接 B樹 1.前言: 動(dòng)態(tài)查找樹主要有:二叉查找樹(Binary Search Tree),平衡二叉查找樹(...
    非典型程序員閱讀 1,164評(píng)論 0 3
  • 之前的文章一直在規(guī)避索引的建立去優(yōu)化數(shù)據(jù)庫(kù),不是不想講何暮,而是這個(gè)太重要奄喂,必須抽出來講。今天我們就來研究下數(shù)據(jù)庫(kù)索引...
    JackFrost_fuzhu閱讀 4,744評(píng)論 0 70
  • 由于偶然的機(jī)遇海洼,我認(rèn)識(shí)了”吳興旗讀書群主”。之后富腊,享受了每天早八晚八的“悅享”分享坏逢!前幾天群主問我們:“每天聽發(fā)...
    快樂的生活閱讀 439評(píng)論 0 0