CSSE 230
BinaryHeaps
Overview
What? To implement insertion and deletion from a binary min-heap, as
well as heapsort.
Why? So that you will better understand the mechanics of the binary
heap algorithms.
Unlike previous assignments, we are giving you very little code to
start with. You
will need to write, document, and unit test a BinaryHeap class from
scratch.
- Checkout the BinaryHeaps project from your individual repository.
- While the heap must hold various types of data (like Strings or
Integers), the data types must at least be Comparable. So declare your class like
this:
public class BinaryHeap<T extends Comparable<? super T>>
{ ... }
- Choose how to store the data internally. Weiss uses arrays, but ArrayLists
also have advantages. I find ArrayLists easier if you don't care about doing heapsort in place. See the note under sort() before you decide.
- If you let Eclipse stub in the methods in the unit tests, it probably won't get all the parameter types
correct. Fix the stubs to be public void insert(T element),
public T deleteMin(), toString(), and public void sort(T[]
array).
- So far in this course, we've given you lots of unit tests since writing
good tests takes LOTS of time. (Consider EditorTrees!) But after this
course, you'll likely be writing your own tests. This is a good chance to
practice. We gave you a couple to get started. But you should write more.
- Before you write any method,
- Document the stubs.
- Then write the method itself.
- Then write a unit test.
- Repeat (b) and (c) as needed to handle increasingly-complicated test
cases.
For toString(), note that you can just call the built-in Array or ArrayList toString() method.
Unit tests will assume the first element is null. For example, an array with
just the element of 17 yield the String, "[null, 17]".
- sort() will mutate the array passed to it so that it its elements are sorted in increasing order. You are required to write a (private) buildHeap helper method.
- Hint: you are not required to do the sort in-place, but may use the less efficient version that copies from the array to the min-heap’s array or ArrayList and back.
Indeed, the in-place version requires a max-heap. However, here's a suggestion of a nifty way to make a max heap. Have a Comparator field, where the default constructor initializes a default (ascending) Comparator.
Use the comparator in your percolation methods. Then, if you want to sort, change the Comparator to a reverse (descending) Comparator - voila, your min-heap code now creates a max-heap.
Then, if you do use an array instead of an ArrayList, you can sort in-place
if you want to.
- Note: this code will become part of the next assignment which will compare the speed of various sorting algorithms.