Adding 3 way quick sort
This commit is contained in:
		
							parent
							
								
									d84cc16d24
								
							
						
					
					
						commit
						20bf3e1673
					
				| @ -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]); | ||||
|     } | ||||
| } | ||||
| @ -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); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user