Adding 3 way quick sort

This commit is contained in:
hitanshu310 2025-02-11 01:18:37 +05:30
parent 6a752c9dc2
commit c9432c8c2b
2 changed files with 64 additions and 0 deletions

View File

@ -0,0 +1,23 @@
package com.hithomelabs.clients.module7;
import com.hithomelabs.princeton1.common.Apple;
import com.hithomelabs.princeton1.module7.Quick;
import com.hithomelabs.princeton1.module7.ThreeWayQuick;
import java.util.Random;
public class ThreeWayQuickSortClient {
public static void main(String[] args) {
int size = 100;
Apple[] apples = new Apple[size];
ThreeWayQuick<Apple> quick = new ThreeWayQuick<>();
for (int i = 0; i < apples.length; i++) {
apples[i] = new Apple(new Random().nextInt(10));
}
quick.sort(apples);
for (int i = 0; i < apples.length; i++)
System.out.println(apples[i]);
}
}

View File

@ -0,0 +1,41 @@
package com.hithomelabs.princeton1.module7;
import com.hithomelabs.princeton1.module5.AbstractCustomSorts;
public class ThreeWayQuick<E> extends AbstractCustomSorts<E> {
@Override
public void sort(E[] arr) {
coreSortingLogic(arr);
}
private void coreSortingLogic(E[] arr) {
int N = arr.length;
threeWaySort(arr, 0, N - 1);
}
private void threeWaySort(E[] arr, int lo, int hi) {
if(hi <= lo)
return;
int k = hi;
int i = lo + 1;
int j = lo;
while (true) {
if (((Comparable<E>) arr[i]).compareTo(arr[j]) < 0) {
exch(arr, i, j++);
i++;
} else if (((Comparable<E>) arr[i]).compareTo(arr[j]) > 0)
exch(arr, i, k--);
else {
i++;
}
if (k < i)
break;
}
threeWaySort(arr, lo, j - 1);
threeWaySort(arr, k + 1, hi);
}
}