• No results found

Binary Search Trees. Definition Of Binary Search Tree. The Operation ascend() Example Binary Search Tree

N/A
N/A
Protected

Academic year: 2021

Share "Binary Search Trees. Definition Of Binary Search Tree. The Operation ascend() Example Binary Search Tree"

Copied!
7
0
0

Loading.... (view fulltext now)

Full text

(1)

Binary Search Trees

• Dictionary Operations: ƒ get(key) ƒ put(key, value) ƒ remove(key) • Additional operations: ƒ ascend()

ƒ get(index)(indexed binary search tree)

ƒ remove(index) (indexed binary search tree)

Complexity Of Dictionary Operations

get(), put() and remove()

Data Structure Worst Case Expected

Hash Table O(n) O(1)

Binary Search Tree O(n) O(log n) Balanced Binary Search Tree O(log n) O(log n)

nis number of elements in dictionary

Complexity Of Other Operations

ascend(), get(index), remove(index)

Data Structure ascend get and remove Hash Table O(D + n log n) O(D + n log n)

Indexed BST O(n) O(n)

Indexed Balanced BST

O(n) O(log n)

Dis number of buckets

Definition Of Binary Search Tree

• A binary tree.

• Each node has a (key, value)pair.

• For every node x, all keys in the left subtree of xare smaller than that in x.

• For every node x, all keys in the right subtree of xare greater than that in x.

Example Binary Search Tree

20 10 6 2 8 15 40 30 25

Only keys are shown.

The Operation ascend()

20 10 6 2 8 15 40 30 25

(2)

The Operation get()

20 10 6 2 8 15 40 30 25

Complexity isO(height) = O(n), where n is number of nodes/elements.

The Operation put()

20 10 6 2 8 15 40 30 25

Put a pair whose key is 35. 35

The Operation put()

Put a pair whose key is 7. 20 10 6 2 8 15 40 30 25 35 7

The Operation put()

20 10 6 2 8 15 40 30 25

Put a pair whose key is 18. 35

7

18

The Operation put()

20 10 6 2 8 15 40 30 25

Complexity of put() is O(height). 35

7

18

The Operation remove()

Three cases:

ƒElement is in a leaf.

ƒElement is in a degree 1 node. ƒElement is in a degree 2 node.

(3)

Remove From A Leaf

Remove a leaf element. key = 7 20 10 6 2 8 15 40 30 25 35 7 18

Remove From A Leaf (contd.)

Remove a leaf element. key = 35 20 10 6 2 8 15 40 30 25 35 7 18

Remove From A Degree 1 Node

Remove from a degree 1 node. key = 40 20 10 6 2 8 15 40 30 25 35 7 18

Remove From A Degree 1 Node (contd.)

Remove from a degree 1 node. key = 15 20 10 6 2 8 15 40 30 25 35 7 18

Remove From A Degree 2 Node

Remove from a degree 2 node. key = 10 20 10 6 2 8 15 40 30 25 35 7 18

Remove From A Degree 2 Node

20 10 6 2 8 15 40 30 25

Replace with largest key in left subtree (or smallest in right subtree).

35

7

(4)

Remove From A Degree 2 Node

20 10 6 2 8 15 40 30 25

Replace with largest key in left subtree (or smallest in right subtree).

35

7

18

Remove From A Degree 2 Node

20 8 6 2 8 15 40 30 25

Replace with largest key in left subtree (or smallest in right subtree).

35

7

18

Remove From A Degree 2 Node

20 8 6 2 8 15 40 30 25

Largest key must be in a leaf or degree 1 node. 35

7

18

Another Remove From A Degree 2 Node

Remove from a degree 2 node. key = 20 20 10 6 2 8 15 40 30 25 35 7 18

Remove From A Degree 2 Node

20 10 6 2 8 15 40 30 25

Replace with largest in left subtree. 35

7

18

Remove From A Degree 2 Node

20 10 6 2 8 15 40 30 25

Replace with largest in left subtree. 35

7

(5)

Remove From A Degree 2 Node

18 10 6 2 8 15 40 30 25

Replace with largest in left subtree. 35

7

18

Remove From A Degree 2 Node

18 10 6 2 8 15 40 30 25 Complexity is O(height). 35 7

Indexed Binary Search Tree

• Binary search tree.

• Each node has an additional field.

ƒ leftSize =number of nodes in its left subtree

Example Indexed Binary Search Tree

20 10 6 2 8 15 40 30 25 35 7 18 0 0 1 1 4 0 0 7 0 0 1 3

leftSizevalues are in red

leftSize And Rank

Rank of an element is its position in inorder (inorder = ascending key order).

[2,6,7,8,10,15,18,20,25,30,35,40]

rank(2) = 0 rank(15) = 5 rank(20) = 7

leftSize(x) = rank(x)with respect to elements in subtree rooted at x

leftSize And Rank

20 10 6 2 8 15 40 30 25 35 7 18 0 0 1 1 4 0 0 7 0 0 1 3 sorted list= [2,6,7,8,10,15,18,20,25,30,35,40]

(6)

get(index) And remove(index)

7 20 10 6 2 8 15 40 30 25 35 7 18 0 0 1 1 4 0 0 0 0 1 3 sorted list= [2,6,7,8,10,15,18,20,25,30,35,40]

get(index) And remove(index)

• if index = x.leftSize desired element is x.element

• if index < x.leftSize desired element is index’th element in left subtree of x

• if index > x.leftSize desired element is (index - x.leftSize-1)’th element in right subtree of x

Applications

(Complexities Are For Balanced Trees)

Best-fit bin packing in O(n log n) time. Representing a linear list so that get(index),

add(index, element), and remove(index) run in O(log(list size)) time (uses an indexed binary tree, not indexed binary search tree).

Can’t use hash tables for either of these applications.

Linear List As Indexed Binary Tree

h e b a d f l j i k c g 0 0 1 1 4 0 0 7 0 0 1 3 list= [a,b,c,d,e,f,g,h,i,j,k,l]

add(5,’m’)

h e b a d f l j i k c g 0 0 1 1 4 0 0 7 0 0 1 3 list= [a,b,c,d,e,f,g,h,i,j,k,l]

add(5,’m’)

h e b a d f l j i k c g 0 0 1 1 4 0 0 7 0 0 1 3

list= [a,b,c,d,e, m,f,g,h,i,j,k,l] find node with element4 (e)

(7)

add(5,’m’)

h e b a d f l j i k c g 0 0 1 1 4 0 0 7 0 0 1 3

list= [a,b,c,d,e, m,f,g,h,i,j,k,l] find node with element4 (e)

add(5,’m’)

h e b a d f l j i k c g 0 0 1 1 4 0 0 7 0 0 1 3

add mas right child of e; former right subtree of ebecomes right subtree of m

m

add(5,’m’)

h e b a d f l j i k c g 0 0 1 1 4 0 0 7 0 0 1 3

add mas leftmost node in right subtree of e

m

add(5,’m’)

• Other possibilities exist.

• Must update someleftSizevalues on path from root to new node.

References

Related documents

Write a function that is given a pointer to the root of a valid binary search tree with unique elements and prints out a list of all the odd numbers stored in the binary search

Classic problems: Binary Tree Preorder Traversal , Binary Tree Inorder Traversal, Binary Tree Pos- torder Traversal, Word Ladder, Validate Binary Search Tree, Flatten Binary Tree

Given a non-empty binary search tree (an ordered binary tree), return the minimum data value found in that tree.. Note that it is not necessary to search the

Trees Trees.. Binary trees that represent algebraic expressions.. A binary search tree of names.. Binary trees with the same nodes but different heights.. Level-by-level numbering of

Algorithm bstSearch(binarySearchTree, desiredObject) // Searches a binary search tree for a given object. // Returns true if the object

Creation is binary search tree algorithm with ppt presentations and the middle element to later functions are performed on word or to search example: check the stack as far?. Deleting

Definition: A binary search tree (BST) is a binary tree whose nodes are organized according to the binary search tree property: keys in the left subtree are all less than the key at

A search begins at the root, and left or right &#34;turns&#34; are made until the target element is located or until the search encounters an empty child, in which