Lecture11
Binary Search Tree
Full vs. Complete Binary Trees
- Full binary tree
- a tree in which every node other than the leaves has two children
data:image/s3,"s3://crabby-images/8d034/8d034887e87fd8a3d000601e5a039ce905a9fe96" alt=""
- Complete binary tree:
- a binary tree in which every level, except possibly the last, is completely filled, and all nodes are as far left as possible
data:image/s3,"s3://crabby-images/0d93b/0d93bb5df1cb5411fd9f0b1a2cf8130c565b0416" alt=""
Complete vs. Incomplete Tree
- Complete Tree:
- All levels are populated left to right
- Last level IS populated left to right(even thought it is not fully populated)
data:image/s3,"s3://crabby-images/bb757/bb757669460a1002364558ce7df6e0b36521d04f" alt=""
- Incomplete Tree
- All levels are populated, BUT
- Last tree is not populated left to right
data:image/s3,"s3://crabby-images/33c55/33c550e538f17a980d882402987ff38ce02c47d1" alt=""
Terminology: Tree Height
- Tree height: maximum node depth in the tree OR height of the root
- Here: tree height H=2
data:image/s3,"s3://crabby-images/fac94/fac94a2518286caab641ec0d2620b38432dff1cc" alt=""
Tree Size: Full Tree
- Tree size: number of all nodes in a tree
- Here: N = 20+ 21+ 22= 2(2+1)-1=7(but this is a very "neat" FULL tree)
- N=20+ 21+ 22+...+2H=2(H+1)-1
data:image/s3,"s3://crabby-images/30b92/30b92437d3e2cdcbffdefb20cd9a4fe33387b624" alt=""
Tree Height = f(Tree size)
- N- Number of Tree Elements | H-Full Tree Height
- N=7--> H=log2(N+1)-1 = log2(7+1)-1=3-1=2
data:image/s3,"s3://crabby-images/2f074/2f07483caab85fbec6a8e08bc87ed59de47b79af" alt=""
BST Operations: Best / Worst Case
data:image/s3,"s3://crabby-images/f3f2d/f3f2da91d712495f2591483ccafc415494146ab5" alt=""
Binary Trees: Underlying Structure
- Trees can be stored in
- arrays
- linked structures
- Trees based on arrays:
- fast access
- fixed size
- deletion
- possible waste of space("null" nodes) if not full
- Trees based on linked structures
- dynamic size
- overhead
Tree as Arrays: Structure
data:image/s3,"s3://crabby-images/c6600/c660045f17c5ed6de15c4b9d980195d643b78c0b" alt=""
data:image/s3,"s3://crabby-images/fe921/fe921056f5be3458858df5cd2284364742bed9b4" alt=""
Tree as Arrays: Indexing
data:image/s3,"s3://crabby-images/d4842/d4842a6e02666a572a9f1891e1c3b4c44200cb69" alt=""
Abstract Data Type: Heap
- Heap ADT
- add (element)
- top ( )
- peek ( )
- size ( )
- isEmpty ( )
Heap
- A heap is a binary tree with the following characteristics:
- It is complete: each tree level is completely filled from left to right, with possible exception of the last level (which is still filled from left to right)
- All nodes/keys satisfy the heap property:
- in heaps for every node its key is greater [MaxHeap] / less than [MinHeap] (or equal to ) the keys of its children nodes.
Binary Search Tree vs. Heap
- Binary Search Tree Properties:
- The left subtree of a given node contains only nodes with keys lesser than the node's key.
- The right subtree of a give node contains only nodes with keys greater than the node's key.
data:image/s3,"s3://crabby-images/2d3c4/2d3c476dd6ff9f144972111a384f3c70b4b49baa" alt=""
- Heap Properties:
- For every node its key is greater than(or equal to)the keys of its children nodes.
MaxHeap vs. MinHeap
- MaxHeap Properties:
- For every node its key is greater than (or equal to) the keys of its children ndoes.
data:image/s3,"s3://crabby-images/f1d3b/f1d3b8f1f61fc422e617c7052e4be00e7f12b865" alt=""
- MinHeap Properties:
- For every node its key is less than(or equal to) the keys of its children nodes.
data:image/s3,"s3://crabby-images/8b42d/8b42d5a49335cd499eb0876f1fd881a9f32755b9" alt=""
Invalid Heaps
- This tree is not complete. It is not a heap.
data:image/s3,"s3://crabby-images/1fe32/1fe3240a5e778fc6210b17d9423fe5483caed3ce" alt=""
- MinHeap property is violated: child node key is less than parent ndoe key(5>2)
data:image/s3,"s3://crabby-images/272e1/272e160e13226083ee21a0d2bac969d651218477" alt=""
Heap: Subtrees are Heaps
Heap property: both left and right subtrees must also be a heap.
data:image/s3,"s3://crabby-images/51318/51318f35f7302999185bcf936a23e2b2690fcd59" alt=""
Heap: Single-node Trees are Heaps
Heap property: single-node trees are valid heaps.
data:image/s3,"s3://crabby-images/49d49/49d49ba037a5fc42b3f6f3dea6663c6226ee512b" alt=""
Heap: add(Element/Key)
Step1: A valid MaxHeap prior to adding a new node. New node location.
data:image/s3,"s3://crabby-images/e3eb9/e3eb9ecd0912f94940af62d391d10b179729b5b7" alt=""
Step2: Heap property temporarily violated!
Step3: Swap Parent and Child elements to restore MaxHeap property
Step4: Swap Parent and Child elements AGAIN to restore MaxHeap property
Step5: Now MaxHeap property is violated one level up
Step6: MaxHeap property is restored. Heap is valid
data:image/s3,"s3://crabby-images/7638c/7638cbc1c52bd7d55b41f7ad99eddf08b1a43e67" alt=""
Heap: top()
Step1: top(max in this case) element(10) is to be removed
Step2: top is removed, there will be a gap. Let's "fill/swap it" with the "last element"
data:image/s3,"s3://crabby-images/ec174/ec17435fd9fb614f80d6cdc3b81606b9ade0867e" alt=""
Step3: Now MaxHeap property is violated
Step4: Parent and LARGEST KEY(9) child elements to restore MaxHeap property
data:image/s3,"s3://crabby-images/45416/45416841e2848f8fb9d4631f40a6caab5f6e5543" alt=""
Step5: MaxHeap property is restored. Heap is valid
Heap: peek()
Step 1: retrieve the top element without removing it.
data:image/s3,"s3://crabby-images/40154/401541b8d7edb247901bc0dfb69fb58d8e576640" alt=""
Application: Heap Sort
- Heap Sort Pseudocode
heapSort(Collection c){
if(c !=null){
Heap h = new Heap();
List out = new List();
while(!h.isEmpty()){
out.add(h.top());
}
}
return out;
}
data:image/s3,"s3://crabby-images/46df3/46df35a649a3e0016a678babc63324049919788f" alt=""
Application: TOP K Elements
- TOP K Elements Pseudocode:
topK(Collection c, int k){
if(c != null & k>0){
int count = 0;
Heap h = new Heap();
List out = new List();
while( !h.isEmpty()){
out.add(h.top());
count++;
if(count > k) break;
}
}
return out;
}
data:image/s3,"s3://crabby-images/c7647/c76477a3b1ecea52985201ba5782428ced42f0b2" alt=""
Abstract Data Type: Priority Queue
-
Priority Queue ADT:
- enqueue (element)
- dequeue ( )
- peek ( )
- size ( )
- isEmpty ( )
-
Comments:
- Underlying Structure is "invisible" to the user:
- different approaches can be used
- consider performance measures for the problem at hand
- Needs to accept various elements
- Underlying Structure is "invisible" to the user: