1) AVL Trees: Show the result of inserting values in this order
into an initially empty AVL tree in this order: 6, 10, 12, 14, 1, 15, 5,
2, 3, 9, 7, 4
2) Binary Min Heaps: For both
questions draw BOTH a picture of the tree structure AND what the final array
looks like. You do not need to show intermediate
values of the array structure. Showing
intermediate pictures of the tree structure is also not required but may allow
some partial credit to be assigned.
Please circle your final answer to both questions.
a) Show the result of inserting the following values in this order into a binary min heap using insert: 10, 12, 1, 14, 6, 5, 8, 15, 3, 9, 7, 4, 11, 13, 2
b) Show the result of using Floyd’s buildheap method (as described in class and in the book) to create a heap out of values assuming you are given them in an array laid out in the order given above.
3) Binary Min Heap Algorithms: : For both of these problems, for full credit your solution should be the most efficient possible – perhaps in the worst case they might need to examine every element in the heap, but in general this should not be the case. You may assume an array layout of the binary min heap as discussed in lecture and in the book. You also may assume that your algorithm has direct access to the heap array (it does not need to manipulate it just by using the standard heap operations – insert, deletemin, findmin, etc.). Your algorithm should not modify the heap (just like a findmin does not modify the heap) – or at the very least, if it does, it should put it back identical to how it was before you started.
a) Give pseudo code for an efficient algorithm to find the maximum value in a binary min heap. What is the worst case big-O running time or your algorithm?
b) Give pseudo code for an efficient algorithm to find all nodes less than a given value in a binary min heap. Your algorithm should just print out the values it finds. What is the worst case big-O running time of your algorithm?
4) Skew Heaps: Show the result
of inserting values in this order into an initially empty skew heap: (1, 2, 6, 3,
4, 8, 7, 5, 9, 10, 11)
5) Leftist Heaps:
Below are two leftist heaps. Show the result of merging them together using the algorithm we discussed in class. You are only required to show the final tree, although if you draw intermediate trees, please circle your final result for ANY credit.
6) Disjoint Sets: Consider the set of initially unrelated elements 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14.
a.)
Draw the final forest of up-trees
that results from the following sequence of operations using on union-by-size.
Break ties in size by keeping the root of the set the first argument belongs
to as the new root. Use the Hw4Union
given below that is able to take any element as a parameter, not necessarily
the name of a set. It finds the set each
element belongs to and then unions those two sets. Be sure to include all elements of the set in
your final answer.
hw4Union(int x, int y) {
u = Find(x); // Find here is done
without path compression.
v = Find(y);
Union(u,v); // Use Union-by-size
}
hw4Union(0,3), hw4Union(3,4), hw4Union(7,9), hw4Union (9,3), hw4Union
(7, 14), hw4Union (8,6), hw4Union (11,5), hw4Union (8,5), hw4Union (6,4), hw4Union
(1,12).
a.) Draw the array representation of your answer above. Use the value -1 to represent a root.
b.) Draw the new forest of up-trees that results from doing a Find(5) with path compression on your forest of up-trees from (a).