Top.Mail.Ru
Ответы
Аватар пользователя
Изменено
Аватар пользователя
Аватар пользователя
Аватар пользователя
Программирование
+2

Пирамидальная сортировка (сортировка кучей). Java

Почему мой код неправильно сортирует массив путём метода сортировки кучей?

Полный код для копирования:
public class Main {

public static void heapSort(int[] a) {
int n = a.length;
for (int i = n / 2 - 1; i >= 0; i--) {
heapify(a, n, i);
}
for (int i = n - 1; i > 0; i--) {
swap(a, i, 0);
heapify(a, i, 0);
}
}

public static void heapify(int[] heap, int n, int i) {
int l = left(i);
int r = right(i);
int largest = i;
if (l < n && heap[l] > heap[i]) {
largest = l;
}
if (r < n && heap[r] > heap[i]) {
largest = r;
}
if (i != largest) {
swap(heap, i, largest);
heapify(heap, n, largest);
}
}

public static int right(int i) {
return 2 * i + 2;
}

public static int left(int i) {
return 2 * i + 1;
}

public static void swap(int[] heap, int i1, int i2) {
int temp = heap[i1];
heap[i1] = heap[i2];
heap[i2] = temp;
}

public static void main(String[] args) {
int[] A = new int[] {2, 3, 1, 5, 4};
heapSort(A);
for (int i = 0; i < A.length; i++)
System.out.println(A[i]);
}
}

По дате
По рейтингу
Аватар пользователя
Новичок

Чти Дональд Кнут. Сортировка и поиск.

Аватар пользователя
Оракул

Аркадий, учитесь искать ошибки в своем коде сами. Вам же хватило ума написать код. Значит должно хватить и найти ошибку. Дебаг в помощь.
Мне лень ее конечно искать.