B-Tree is a specialized m-way tree that can be widely used for disk access. A B-Tree of order m can have at most m-1 keys and m children. One of the main reason of using B-Tree is its capability to store large number of keys in a single node and large key values by keeping the height of the tree relatively small.
Properties of B-Tree –
- A B-Tree is defined by the term minimum degree ‘t’
- Every node except root must contain at least (t – 1) keys. Root may contain minimum 1 key.
- All nodes (including root) may contain at most (2t – 1) keys.
- Number of children of a node is equal to the number of keys in it plus 1.
- All keys of a node are sorted in increasing order. The child between two keys k1 and k2 contains all keys in the range from k1 and k2.
B-Tree Insertion
Let us understand the algorithm with an example tree of minimum degree ‘t’ as 3 and a sequence of integers 10, 20, 30, 40, 50, 60, 70, 80 and 90 in an initially empty B-Tree.
Initially root is NULL. Let us first insert 10.
data:image/s3,"s3://crabby-images/78955/789552624f44c782e6c449d50f66e88584e6f089" alt=""
Let us now insert 20, 30, 40 and 50. They all will be inserted in root because maximum number of keys a node can accommodate is 2*t – 1 which is 5.
data:image/s3,"s3://crabby-images/3b525/3b525cf8fcc36b031d077275ccbe3496bf7e53cc" alt=""
Let us now insert 60. Since root node is full, it will first split into two, then 60 will be inserted into the appropriate child.
data:image/s3,"s3://crabby-images/fb4b6/fb4b60355a745385e24475a554fbad261e853806" alt=""
Let us now insert 70 and 80. These new keys will be inserted into the appropriate leaf without any split.
data:image/s3,"s3://crabby-images/31927/31927f7f11c3f24a34d8da573116315cec8a4f1f" alt=""
Let us now insert 90. This insertion will cause a split. The middle key will go up to the parent.
data:image/s3,"s3://crabby-images/ef305/ef3056ba11eb6c20051da7600efb41474e68bbe6" alt=""
Initial Tree
data:image/s3,"s3://crabby-images/0a7d0/0a7d08d5a60210ca9f53455ee807e6663274a24d" alt=""
After delete 60 the Tree will be
data:image/s3,"s3://crabby-images/9357d/9357d4d935dfb56b38ab2b2b489b26aa22959868" alt=""
After delete 20 the Tree will be
data:image/s3,"s3://crabby-images/116c2/116c2a862b50c5e7bed1e5fb364111061fdc653f" alt=""
After delete 30 the Tree will be
data:image/s3,"s3://crabby-images/6182f/6182fed1b672f279f158fadf9769844fd1d4afa5" alt=""
0 टिप्पणियाँ:
Post a Comment