Я пытаюсь реализовать алгоритм сортировки слиянием из книги «Введение в алгоритм», используя Java, но когда я выполняю код, у меня выводится полусортировка:
input = 2,4,5,1,2,3,6,7
output = 2,2,3,4,5,1,2,7
public class Main {
public static void main(String[] args) {
int A[] = {
2, 4, 5, 1, 2, 3, 6, 7
};
int B[] = new Main().mergeSort(A, 0, A.length);
for (int i = 0; i < B.length; i++) {
System.out.println(B[i]);
}
}
void merge(int A[], int p, int q, int r) {
int n1 = q - p + 1;
int n2 = r - q;
System.out.println("-n1: " + n1 + " n2: " + n2);
int L[] = new int[n1];
int R[] = new int[n2];
for (int i = 0; i < n1; i++) {
L[i] = A[p + i];
System.out.println("L--|" + L[i]);
}
for (int j = 0; j < n2; j++) {
R[j] = A[q + j];
System.out.println("R--|" + R[j]);
}
int i = 0;
int j = 0;
for (int k = p; k < r; k++) {
if (L[i] <= R[j]) {
A[k] = L[i];
System.out.println("A--|" + A[k] + " i: " + i);
i = i + 1;
} else {
A[k] = R[j];
System.out.println("A--|" + A[k] + " j: " + j);
j = j + 1;
}
if (i == L.length || j == R.length) break;
}
}
int[] mergeSort(int A[], int p, int r) {
if (p < r) {
int q = (int) Math.floor((p + r) / 2);
mergeSort(A, p, q);
mergeSort(A, q + 1, r);
System.out.println("q: " + q + " p: " + p + " r:" + r);
merge(A, p, q, r);
}
return A;
}
}
Если кто-то может помочь мне в этом коде, я был бы благодарен. Я знаю, что в Java есть много готовых реализаций, и в этой форме я просто хочу знать, что не так с моим кодом.