Я пробовал разные подходы.
Изменение типа возвращаемого значения quickSort на int и добавление параметра "int numPivots" в метод. Затем я добавил numPivots ++; после вызова метода разбиения и возвращает numPivots в конце. При передаче 0 в качестве аргумента возвращаемое значение в моем методе main было 1. Это имеет смысл, поскольку это первое значение, которое будет возвращено после всех рекурсий. Я просто не могу понять, что мне нужно изменить, чтобы сделать эту работу.
Создание "ArrayList pivots" в методе main и передача его в качестве аргумента для быстрой сортировки и оттуда к разделу. Я заполнил его всеми опорными точками, но все еще не получил правильный результат. Это был странный подход, но я потерял самообладание.
Создание переменной экземпляра и методов для ее увеличения / получения ее значения. Это тоже не сработало и казалось глупым.
Вот код
public static void quickSort(int[] arr, int start, int end){
int partition = partition(arr, start, end);
if(partition-1>start) {
quickSort(arr, start, partition - 1);
}
if(partition+1<end) {
quickSort(arr, partition + 1, end);
}
}
public static int partition(int[] arr, int start, int end){
int pivot = arr[end];
//checks if left pointer < pivot
for(int i=start; i<end; i++){
if(arr[i]<pivot){
int temp= arr[start];
arr[start]=arr[i];
arr[i]=temp;
start++;
}
}
//switches pivots
int temp = arr[start];
arr[start] = pivot;
arr[end] = temp;
return start;
}
Также: я думал, что quickSort будет работать с 2 указателями, указателем влево и указателем вправо. После неудачной попытки написать собственный алгоритм быстрой сортировки, я просто взял его из учебника. Это смущает меня, потому что он не использует rightPointer.
Я взял ручку и бумагу, чтобы выполнить шаги, и я думаю, что понял, как это работает, но это тот же алгоритм, как объяснено здесь ?
Я знаю, это много вопросов. Спасибо за ваше время!