Я знаю, что существует множество методов HeapSort для переполнения стека, однако ни один из них не обязательно поможет мне с тем, над чем я работаю.
У меня есть представление о том, что такое куча, я просто не знаю, как обязательно получить эти значения и отсортировать их, чтобы сохранить их в массиве.
Поэтому мои инструкции гласят: метод static heapSort (Comparable [], int) должен выполнять сортировку по месту (от минимального значения к наибольшему значению) массива. Второй параметр указывает количество
заполненные элементы в массиве. Чтобы «обработать сам [массив] как max-heap», этот метод может создать локальный экземпляр MaxHeapPriorityQueue и назначить первый параметр elementData, а второй параметр - size. Поскольку данные начинаются с индекса 0, вы не сможете использовать большинство других частных вспомогательных методов. Когда метод завершится, параметр массива будет отсортирован.
public class MaxHeapPriorityQueue<E extends Comparable<E>>
{
private E[] elementData;
private int size;
@SuppressWarnings("unchecked")
public MaxHeapPriorityQueue()
{
elementData = (E[]) new Comparable[10];
size = 0;
}
public static void heapSort(Comparable[] a, int size)
{
MaxHeapPriorityQueue elementData = new MaxHeapPriorityQueue();
//PriorityQueue<Comparable> pq = new PriorityQueue();
for (Comparable n : a)
{
elementData.add(n);
}
for (int i = 0; i < size; i++)
{
a[i] = elementData.remove();
}
}
public class MHPQIterator implements java.util.Iterator<E>
{
private int index;
public boolean hasNext()
{
if(size == 0)
{
return false;
}
else
{
return (index < size);
}
}
public E next()
{
index++;
return elementData[index];
}
}
Этот алгоритм был основан на моих заметках, однако я в основном борюсь с тем, что я прокомментировал в первой строке метода. Я предоставил два других класса, которые связаны с этим методом. У меня также есть другие методы, но, как я уже говорил ранее в инструкциях, родители, leftChild, rightChild и т. Д. Не будут использоваться. Однако было упомянуто о попытке создать два частных вспомогательных метода, таких как закрытый метод E removeSort () и закрытый метод void bubbleDown (int index).