Balanced search trees: trees.

Slides:



Advertisements
Similar presentations
The Dictionary ADT Definition A dictionary is an ordered or unordered list of key-element pairs, where keys are used to locate elements in the list. Example:
Advertisements

Chapter 4: Trees Part II - AVL Tree
AA Trees another alternative to AVL trees. Balanced Binary Search Trees A Binary Search Tree (BST) of N nodes is balanced if height is in O(log N) A balanced.
Balanced Search Trees. 2-3 Trees Trees Red-Black Trees AVL Trees.
A balanced life is a prefect life.
1 B trees Nodes have more than 2 children Each internal node has between k and 2k children and between k-1 and 2k-1 keys A leaf has between k-1 and 2k-1.
6/14/2015 6:48 AM(2,4) Trees /14/2015 6:48 AM(2,4) Trees2 Outline and Reading Multi-way search tree (§3.3.1) Definition Search (2,4)
Liang, Introduction to Java Programming, Eighth Edition, (c) 2011 Pearson Education, Inc. All rights reserved Chapter Trees and B-Trees.
Multi-Way search Trees Trees: a. Nodes may contain 1 or 2 items. b. A node with k items has k + 1 children c. All leaves are on same level.
© 2004 Goodrich, Tamassia (2,4) Trees
CSE 326: Data Structures B-Trees Ben Lerner Summer 2007.
Data Structures Using C++ 2E Chapter 11 Binary Trees and B-Trees.
© 2006 Pearson Addison-Wesley. All rights reserved13 A-1 Chapter 13 Advanced Implementation of Tables.
C++ Programming: Program Design Including Data Structures, Third Edition Chapter 20: Binary Trees.
2-3 Trees Professor Sin-Min Lee. Contents n Introduction n The 2-3 Trees Rules n The Advantage of 2-3 Trees n Searching For an Item in a 2-3 Tree n Inserting.
Binary Trees Chapter 6.
IntroductionIntroduction  Definition of B-trees  Properties  Specialization  Examples  2-3 trees  Insertion of B-tree  Remove items from B-tree.
B-Tree. B-Trees a specialized multi-way tree designed especially for use on disk In a B-tree each node may contain a large number of keys. The number.
CHAPTER 71 TREE. Binary Tree A binary tree T is a finite set of one or more nodes such that: (a) T is empty or (b) There is a specially designated node.
Chapter 19: Binary Trees. Objectives In this chapter, you will: – Learn about binary trees – Explore various binary tree traversal algorithms – Organize.
Chapter 6 Binary Trees. 6.1 Trees, Binary Trees, and Binary Search Trees Linked lists usually are more flexible than arrays, but it is difficult to use.
Balanced search trees: 2-3 trees. 2-3 trees allow us to process ordered lists in more efficient way than binary trees with an ordering property. Recall.
Chapter 13 A Advanced Implementations of Tables. © 2004 Pearson Addison-Wesley. All rights reserved 13 A-2 Balanced Search Trees The efficiency of the.
AVL Trees. AVL Node Structure The AVL node structure follows the same structure as the binary search tree, with the addition of a term to store the.
2-3 Trees Extended tree.  Tree in which all empty subtrees are replaced by new nodes that are called external nodes.  Original nodes are called internal.
Balanced search trees: trees (or 2-4) trees improve the efficiency of insertItem and deleteItem methods of 2-3 trees, because they are performed.
© 2004 Goodrich, Tamassia Trees
 B-tree is a specialized multiway tree designed especially for use on disk  B-Tree consists of a root node, branch nodes and leaf nodes containing the.
(2,4) Trees1 What are they? –They are search Trees (but not binary search trees) –They are also known as 2-4, trees.
The Heap ADT A heap is a complete binary tree where each node’s datum is greater than or equal to the data of all of the nodes in the left and right subtrees.
Balanced Search Trees 2-3 Trees AVL Trees Red-Black Trees
Lecture Trees Professor Sin-Min Lee.
TCSS 342, Winter 2006 Lecture Notes
AA Trees.
File Organization and Processing Week 3
B-Trees B-Trees.
Multiway Search Trees Data may not fit into main memory
Search Trees.
Chapter 10 Search Trees 10.1 Binary Search Trees Search Trees
B+ Trees What are B+ Trees used for What is a B Tree What is a B+ Tree
B+-Trees.
Lecture 22 Binary Search Trees Chapter 10 of textbook
B+ Tree.
ITEC 2620M Introduction to Data Structures
Trees 4 The B-Tree Section 4.7
Chapter Trees and B-Trees
Chapter Trees and B-Trees
(edited by Nadia Al-Ghreimil)
The Dictionary ADT Definition A dictionary is an ordered or unordered list of key-element pairs, where keys are used to locate elements in the list. Example:
Data Structures Balanced Trees CSCI
(2,4) Trees (2,4) Trees 1 (2,4) Trees (2,4) Trees
B+ Trees What are B+ Trees used for What is a B Tree What is a B+ Tree
Height Balanced Trees 2-3 Trees.
Multi-Way Search Trees
Balanced-Trees This presentation shows you the potential problem of unbalanced tree and show two way to fix it This lecture introduces heaps, which are.
(2,4) Trees /26/2018 3:48 PM (2,4) Trees (2,4) Trees
Balanced-Trees This presentation shows you the potential problem of unbalanced tree and show two way to fix it This lecture introduces heaps, which are.
(2,4) Trees (2,4) Trees (2,4) Trees.
2-3-4 Trees Red-Black Trees
(2,4) Trees 2/15/2019 (2,4) Trees (2,4) Trees.
(2,4) Trees /24/2019 7:30 PM (2,4) Trees (2,4) Trees
(edited by Nadia Al-Ghreimil)
(2,4) Trees (2,4) Trees (2,4) Trees.
Red Black Trees (Guibas Sedgewick 78)
Basic Data Structures - Trees
(2,4) Trees /6/ :26 AM (2,4) Trees (2,4) Trees
B-Trees.
Binary Search Trees < > = Dictionaries
CS210- Lecture 20 July 19, 2005 Agenda Multiway Search Trees 2-4 Trees
Balanced search trees: 2-3 trees.
Presentation transcript:

Balanced search trees: 2-3-4 trees. 2-3-4 (or 2-4) trees improve the efficiency of insertItem and deleteItem methods of 2-3 trees, because they are performed on the path from the root to the leaf. However, they require more memory for storing 3 data items and 4 pointers in each node. Definition: A 2-3-4 tree is a general tree which satisfies the following properties: Each node may store three data items. Each node may have four children. The second and third data items in any node may be empty, in which case sentinel value emptyFlag is stored there (assume emptyFlag := 0). If they are not empty, the first data item precedes the second one according to the specified ordering relationship, the second data item precedes the third data item. For each node, data in the first child precedes the first data item in the node; data in the second child follows the first data item, but precedes the second; data in the third child follows the second data item, but precedes the third; data in the fourth child follows the third data item. All leaf nodes are on the same level.

Example 2-3-4 tree 4 2 6 8 1 3 5 7 9 10 11 Class Node234tree { 2 6 8 1 3 5 7 9 10 11 Class Node234tree { Node234tree firstChild; Node234tree secondChild; Node234tree thirdChild; Node234tree fourthChild; Node234tree parent; int firstItem; int secondItem; int thirdItem; .... class methods follow }

Search in 2-3-4 trees The search algorithm is similar to that in 2-3 trees and binary search trees. In the example 2-3-4 tree, the search for 10 is carried out as follows: 1. Compare 10 to the only item in the root. 10 > 4, continue the search in the second child. 2. 10 > 6 and 10 > 8, continue the search in the third child. 3. 10 > 9, 10 = 10. Stop. As in 2-3 trees, the efficiency of the search operation is guaranteed to be O(log n). On average, it will be better that the search efficiency in 2-3 trees, because the height of a 2-3-4 tree might be less than the height of the 2-3 tree with the same data.

Insertion in 2-3-4 trees Step 1 Search for the item to be inserted (same as in 2-3 trees). Step 2 Insert at the leaf level. The following cases are possible: The termination node is a 2-node. Then, make it a 3-node, and insert the new item appropriately. The termination node is a 3-node. Then, make it a 4-node, and insert the new item appropriately. The termination node is a 4 node. Split is, pass the middle to the parent, and insert the new item appropriately. General rules for inserting new nodes in 2-3-4 trees: Rule 1: During the search step, every time a 2-node connected to a 4-node is encountered, transform it into a 3-node connected to two 2-nodes. Rule 2: During the search step, every time a 3-node connected to a 4-node is encountered, transform it into a 4-node connected to two 2-nodes. Note that two 2-nodes resulting from these transformations have the same number of children as the original 4-node. This is why the split of a 4-node does not affect any nodes below the level where the split occurs.

Efficiency of search and insert operations Result 1: Search in a 2-3-4 tree with N nodes takes at most O(log N) time. This is in case if all nodes are 2 nodes. If there are 3-nodes and 4-nodes on the tree, the search will take less than (log N) time. Result 2: Insertion into a 2-3-4 tree takes less than O(log N) time, and on average requires less than 1 node split.

Deletion in 2-3-4 tree Consider our example tree 4 2 6 8 2 6 8 1 3 5 7 9 10 11 The following special cases (with multiple sub-cases each) are possible: Case 1 (three sub-cases): The item is deleted from a leaf node (a node with external children), which currently contains 2 or 3 items. Easy sub-cases – delete the item transforming a 4-node into a 3 node, or a 3 node into a 2 node. No other nodes are affected. Example: delete 9 – the existing 4 node, containing 9, 10, and 11 is transformed into a 3 node, containing 10 and 11. Deleting from a 2-node (the third sub-case) requires an item from the parent node to be drawn, which in turn must be replaced by an item from the sibling note (if the sibling node is NOT a 2-node as well). See case 2.

Deletion in 2-3-4 tree (contd.) Case 2 (with several more sub-cases) Delete from a node that has non-external children. For example, delete 8. This case can be reduced to case 1 by finding the item that precedes the one to be deleted in in-order traversal (7, in our example) and exchanging the two items. If 7 were part of a 3- or 4- node, 8 would have been deleted easily. However, since 8 is now the only item in the node, we have a case of underflow. This requires that an item from the parent node be transferred to the underflow node, and substituted in the parent node by an item from the sibling node. In our example, 7 will be transferred back to where it was, and 9 will move to the parent node to fill the gap. However, if the sibling node is also a 2-node, the so-called fusing takes place. That is, the two 2-node siblings are “fused” in a single 3-node, after an item is transferred from the parent node. The later suggests that the parent can now handle one less child, and it indeed has one child less after two of its former children are fused. The last sub-case suggests that a parent node is also a 2-node. Then, it must in turn borrow from its parent, etc., resulting in the 2-3-4 tree becoming one level shorter.