Compare commits
	
		
			7 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 96ce281b20 | |||
| 67a7b0e096 | |||
| 9e9d30accf | |||
| f12dd3574e | |||
| 0f662bf89c | |||
| 2679715bb2 | |||
| b8f6081173 | 
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,6 +1,7 @@ | |||||||
| # Ignore Gradle project-specific cache directory | # Ignore Gradle project-specific cache directory | ||||||
| .gradle | .gradle | ||||||
| 
 | # Igonre the .idea directory | ||||||
|  | .idea | ||||||
| # Ignore Gradle build output directory | # Ignore Gradle build output directory | ||||||
| build | build | ||||||
| bin | bin | ||||||
							
								
								
									
										1
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
								
							| @ -14,6 +14,7 @@ | |||||||
|             <option value="$PROJECT_DIR$/module5" /> |             <option value="$PROJECT_DIR$/module5" /> | ||||||
|             <option value="$PROJECT_DIR$/module6" /> |             <option value="$PROJECT_DIR$/module6" /> | ||||||
|             <option value="$PROJECT_DIR$/module7" /> |             <option value="$PROJECT_DIR$/module7" /> | ||||||
|  |             <option value="$PROJECT_DIR$/module8" /> | ||||||
|           </set> |           </set> | ||||||
|         </option> |         </option> | ||||||
|       </GradleProjectSettings> |       </GradleProjectSettings> | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ dependencies { | |||||||
|     implementation project(':module5') |     implementation project(':module5') | ||||||
|     implementation project(':module6') |     implementation project(':module6') | ||||||
|     implementation project(':module7') |     implementation project(':module7') | ||||||
|  |     implementation project(':module8') | ||||||
|     implementation project(':common') |     implementation project(':common') | ||||||
|     testImplementation project(':common') |     testImplementation project(':common') | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,23 @@ | |||||||
|  | package com.hithomelabs.clients.module8; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module8.HeapSort; | ||||||
|  | 
 | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class HeapSortClient { | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args) { | ||||||
|  |         int size = 10; | ||||||
|  |         Apple[] apples = new Apple[size]; | ||||||
|  |         HeapSort<Apple> heap = new HeapSort<Apple>(); | ||||||
|  | 
 | ||||||
|  |         for (int i = 0; i < apples.length; i++) { | ||||||
|  |             apples[i] = new Apple(new Random().nextInt(10)); | ||||||
|  |         } | ||||||
|  |         heap.sort(apples); | ||||||
|  |         for (int i = 0; i < apples.length; i++) | ||||||
|  |             System.out.println(apples[i]); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -5,100 +5,28 @@ import java.util.Iterator; | |||||||
| import javax.annotation.Nonnull; | import javax.annotation.Nonnull; | ||||||
| 
 | 
 | ||||||
| public class ArrayQueue<E> extends Queue<E>{ | public class ArrayQueue<E> extends Queue<E>{ | ||||||
| 
 |  | ||||||
|     // insertion from tail, removal from head |  | ||||||
|     public static final int DEFAULT_CAPACITY = 10; |  | ||||||
|     private int capacity; |  | ||||||
|     private int tail; |  | ||||||
|     private int head; |  | ||||||
|     private int size; |  | ||||||
|     private E[] arr; |  | ||||||
| 
 |  | ||||||
|     public ArrayQueue(){ |  | ||||||
|         this(DEFAULT_CAPACITY); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public ArrayQueue(int capacity){ |  | ||||||
|         this.capacity = capacity; |  | ||||||
|         arr = (E[]) new Object[this.capacity]; |  | ||||||
|         size = 0; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isEmpty() { |     public boolean isEmpty() { | ||||||
|         return size == 0; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public E dequeue() { |     public E dequeue() { | ||||||
|         if(isEmpty()) |  | ||||||
|         return null; |         return null; | ||||||
|         else{ |  | ||||||
|             E element = arr[head]; |  | ||||||
|             // Garbage collection |  | ||||||
|             arr[head] = null; |  | ||||||
|             head = (head+1)%capacity; |  | ||||||
|             size = size - 1; |  | ||||||
|             if(capacity >= 40 && size < capacity/4){ |  | ||||||
|                 capacity = capacity/2; |  | ||||||
|                 resize(capacity, capacity*2); |  | ||||||
|             } |  | ||||||
|             return element; |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void enqueue(E element) { |     public void enqueue(E element) { | ||||||
|         // We plan capacity expansion if needed |  | ||||||
|         if (size == capacity){ |  | ||||||
|             capacity = capacity * 2; |  | ||||||
|             resize(capacity, capacity/2); |  | ||||||
|         } |  | ||||||
|         arr[tail] = element; |  | ||||||
|         tail = (tail + 1) % capacity; |  | ||||||
|         ++size; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // When resize takes place always the original array is full, so copy the complete array as is |  | ||||||
|     private void resize(int capacity, int oldCapacity) { |  | ||||||
|         E[] resizedArr = (E[]) new Object[capacity]; |  | ||||||
|         for(int i = 0; i < size; i++) { |  | ||||||
|             resizedArr[i] = arr[head]; |  | ||||||
|             // halving because capacity has now doubled |  | ||||||
|             arr[head] = null; |  | ||||||
|             head = (head + 1) % oldCapacity; |  | ||||||
|         } |  | ||||||
|         arr = resizedArr; |  | ||||||
|         // When resizing takes place, we bring the head to 0 and the tail to size |  | ||||||
|         // tail is where new inserts will be made and head will be where elements will be removed |  | ||||||
|         tail = size; |  | ||||||
|         head = 0; |  | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public int size() { |     public int size() { | ||||||
|         return size; |         return 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Nonnull |  | ||||||
|     public Iterator<E> iterator() { |     public Iterator<E> iterator() { | ||||||
|         return new Iterator<E>() { |         return null; | ||||||
|             int counter = size; |  | ||||||
|             int pointer = head; |  | ||||||
|             @Override |  | ||||||
|             public boolean hasNext() { |  | ||||||
|                 return counter != 0; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             @Override |  | ||||||
|             public E next() { |  | ||||||
|                 E element = arr[pointer]; |  | ||||||
|                 pointer = (pointer + 1)% capacity; |  | ||||||
|                 --counter; |  | ||||||
|                 return element; |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -5,94 +5,28 @@ import javax.annotation.Nonnull; | |||||||
| // Concrete implementation of stack using arrays | // Concrete implementation of stack using arrays | ||||||
| // Creating a generic stack of type E | // Creating a generic stack of type E | ||||||
| public class ArrayStack<E> extends Stack<E> { | public class ArrayStack<E> extends Stack<E> { | ||||||
| 
 |  | ||||||
|     // Capacity and size are two variables, capacity determines total capacity of array, capacity defaults at 10 |  | ||||||
|     // every time size == capacity, capacity = 2 * capacity |  | ||||||
|     private static final int DEFAULT_CAPACITY = 10; |  | ||||||
|     private int capacity; |  | ||||||
|     private int size; |  | ||||||
|     private E[] arr; |  | ||||||
| 
 |  | ||||||
|     public ArrayStack(int capacity){ |  | ||||||
|         this.capacity = capacity; |  | ||||||
|         arr = (E[]) new Object[this.capacity]; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // Constructor chaining, default constructor will call parametrized constructor with default initial capacity 10 |  | ||||||
|     public ArrayStack(){ |  | ||||||
|         this(DEFAULT_CAPACITY); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isEmpty() { |     public boolean isEmpty() { | ||||||
|         return size == 0; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void changeCapacity(int newCapacity){ |  | ||||||
|         E[] resizedArr = (E[]) new Object[newCapacity]; |  | ||||||
|         for (int i = 0; i < size; i++) |  | ||||||
|             resizedArr[i] = arr[i]; |  | ||||||
|         arr = resizedArr; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private void incrementSize(){ |  | ||||||
|         if (size == capacity){ |  | ||||||
|             capacity = 2 * capacity; |  | ||||||
|             changeCapacity(capacity); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // Push always happens at the end of the stack |  | ||||||
|     // Say the size of the stack is 1, new element gets inserted  at 1 |  | ||||||
|     @Override |     @Override | ||||||
|     public void push(E element) { |     public void push(E element) { | ||||||
|         // Lazy approach, we assume size to always be lesser than capacity | 
 | ||||||
|         incrementSize(); |  | ||||||
|         arr[size++] = element; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public E pop() { |     public E pop() { | ||||||
|         if (isEmpty()) |  | ||||||
|         return null; |         return null; | ||||||
|         else{ |  | ||||||
|             E e = arr[--size]; |  | ||||||
|             arr[size] = null; |  | ||||||
|             checkResize(); |  | ||||||
|             return e; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private void checkResize() { |  | ||||||
|         if (size < capacity / 4 && capacity >= 20){ |  | ||||||
|             capacity = capacity / 2; |  | ||||||
|             changeCapacity(capacity); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public int size() { |     public int size() { | ||||||
|         return size; |         return 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Nonnull |  | ||||||
|     public Iterator<E> iterator() { |     public Iterator<E> iterator() { | ||||||
|         return new Iterator<E>() { |         return null; | ||||||
| 
 |  | ||||||
|             int current = 0; |  | ||||||
| 
 |  | ||||||
|             @Override |  | ||||||
|             public boolean hasNext() { |  | ||||||
|                 return current != size; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             @Override |  | ||||||
|             public E next() { |  | ||||||
|                 E element = arr[current]; |  | ||||||
|                 current = current + 1; |  | ||||||
|                 return element; |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -4,71 +4,28 @@ import javax.annotation.Nonnull; | |||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| 
 | 
 | ||||||
| public class LinkedQueue<E> extends Queue<E>{ | public class LinkedQueue<E> extends Queue<E>{ | ||||||
| 
 |  | ||||||
|     Node head; |  | ||||||
|     Node tail; |  | ||||||
|     int size; |  | ||||||
| 
 |  | ||||||
|     private class Node{ |  | ||||||
|         E value; |  | ||||||
|         Node next; |  | ||||||
| 
 |  | ||||||
|         Node(E value){ |  | ||||||
|             this.value = value; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isEmpty() { |     public boolean isEmpty() { | ||||||
|         return size==0; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public E dequeue() { |     public E dequeue() { | ||||||
|         if(isEmpty()) |  | ||||||
|         return null; |         return null; | ||||||
|         E element = head.value; |  | ||||||
|         // Only a single element is present |  | ||||||
|         if (head == tail){ |  | ||||||
|             tail = null; |  | ||||||
|         } |  | ||||||
|         head = head.next; |  | ||||||
|         --size; |  | ||||||
|         return element; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void enqueue(E element) { |     public void enqueue(E element) { | ||||||
|         Node newNode = new Node(element); | 
 | ||||||
|         if(isEmpty()) |  | ||||||
|             head = newNode; |  | ||||||
|         else |  | ||||||
|             tail.next = newNode; |  | ||||||
|         tail = newNode; |  | ||||||
|         ++size; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public int size() { |     public int size() { | ||||||
|         return size; |         return 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Nonnull |  | ||||||
|     public Iterator<E> iterator() { |     public Iterator<E> iterator() { | ||||||
|         return new Iterator<E>() { |         return null; | ||||||
|             Node current = head; |  | ||||||
|             @Override |  | ||||||
|             public boolean hasNext() { |  | ||||||
|                 return current != null; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             @Override |  | ||||||
|             public E next() { |  | ||||||
|                 E element = current.value; |  | ||||||
|                 current = current.next; |  | ||||||
|                 return element; |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,70 +3,28 @@ import java.util.Iterator; | |||||||
| 
 | 
 | ||||||
| // Creating a concrete linked Implementation of Stack | // Creating a concrete linked Implementation of Stack | ||||||
| public class LinkedStack<E> extends Stack<E>{ | public class LinkedStack<E> extends Stack<E>{ | ||||||
| 
 |  | ||||||
|     // No need for an explicit constructor as size will be initialized to 0 and root to null |  | ||||||
|     private int size; |  | ||||||
|     private Node first; |  | ||||||
| 
 |  | ||||||
|     // By default instance variables are package private |  | ||||||
|     private class Node{ |  | ||||||
|         E value; |  | ||||||
|         Node next; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // Will return true if size is 0 |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isEmpty() { |     public boolean isEmpty() { | ||||||
|         return (this.size == 0); |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Adds an element to the start of a linked list |  | ||||||
|     @Override |     @Override | ||||||
|     public void push(E element) { |     public void push(E element) { | ||||||
|         Node newNode = new Node(); | 
 | ||||||
|         newNode.value = element; |  | ||||||
|         newNode.next = first; |  | ||||||
|         first = newNode; |  | ||||||
|         this.size = this.size + 1; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public E pop() { |     public E pop() { | ||||||
|         if (this.isEmpty()) |  | ||||||
|         return null; |         return null; | ||||||
|         else{ |  | ||||||
|             Node toBePopped = first; |  | ||||||
|             first = first.next; |  | ||||||
|             this.size = this.size - 1; |  | ||||||
|             return toBePopped.value; |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public int size() { |     public int size() { | ||||||
|         return this.size; |         return 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public Iterator<E> iterator() { |     public Iterator<E> iterator() { | ||||||
|         return new Iterator<E>() { |         return null; | ||||||
| 
 |  | ||||||
|             // Internal classes can access outer objects |  | ||||||
|             Node current = first; |  | ||||||
|             @Override |  | ||||||
|             public boolean hasNext() { |  | ||||||
|                 return current != null; |  | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|             @Override |  | ||||||
|             public E next() { |  | ||||||
|                 E element = current.value; |  | ||||||
|                 current = current.next; |  | ||||||
|                 return element; |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -4,12 +4,14 @@ public abstract class AbstractCustomSorts<E> { | |||||||
| 
 | 
 | ||||||
|     public abstract void sort(E[] arr); |     public abstract void sort(E[] arr); | ||||||
| 
 | 
 | ||||||
|  |     // TODO: Implement this method | ||||||
|     public void exch(E[] arr, int j, int i) { |     public void exch(E[] arr, int j, int i) { | ||||||
|         E temp = arr[i]; |         E temp = arr[j]; | ||||||
|         arr[i] = arr[j]; |         arr[j] = arr[i]; | ||||||
|         arr[j] = temp; |         arr[i] = temp; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // TODO: Implement this method | ||||||
|     public boolean less(Comparable<E> e1, E e2) { |     public boolean less(Comparable<E> e1, E e2) { | ||||||
|         return e1.compareTo(e2) < 0; |         return e1.compareTo(e2) < 0; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1,23 +1,31 @@ | |||||||
| package com.hithomelabs.princeton1.module5; | package com.hithomelabs.princeton1.module5; | ||||||
| 
 | 
 | ||||||
| public class Insertion<E> extends AbstractCustomSorts<E> { | public class Insertion<E> extends AbstractCustomSorts<E> { | ||||||
| 
 |     @Override | ||||||
|     public void sort(E[] arr) { |     public void sort(E[] arr) { | ||||||
|         if (arr == null) return; |  | ||||||
|         else{ |  | ||||||
|         int N = arr.length; |         int N = arr.length; | ||||||
|             // * * swap arr[i] with each element greater to it's left | 
 | ||||||
|             for (int i = 1; i < N; i++){ |         for(int i=0; i<N; i++){ | ||||||
|                 int j = i; |             for(int j=i; j>0; j--){ | ||||||
|                 while(j >= 1 && less((Comparable<E>)arr[j], arr[j-1])){ |                 if(less( (Comparable<E>) arr[j], arr[j-1])) | ||||||
|                     exch(arr, j, j-1); |                     exch(arr, j, j-1); | ||||||
|                     j = j-1; |                 else | ||||||
|  |                     break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     } |     public void sort(E[] arr, int h) { | ||||||
| 
 |         int N = arr.length; | ||||||
| 
 | 
 | ||||||
|  |         for(int i=0; i<N; i++){ | ||||||
|  |             for(int j=i; j>0; j=j-h){ | ||||||
|  |                 if(less( (Comparable<E>) arr[j], arr[j-1])) | ||||||
|  |                     exch(arr, j, j-1); | ||||||
|  |                 else | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,23 +1,22 @@ | |||||||
| package com.hithomelabs.princeton1.module5; | package com.hithomelabs.princeton1.module5; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| public class Selection<E> extends AbstractCustomSorts<E>{ |  | ||||||
| 
 |  | ||||||
| /* | /* | ||||||
|  * * Selection sort "selects" the smallest element and swaps it with arr[0] of the array |  * * Selection sort "selects" the smallest element and swaps it with arr[0] of the array | ||||||
|  * * Then proceeds to do the same swapping arr[i] with arr[i:arr.length-1] |  * * Then proceeds to do the same swapping arr[i] with arr[i:arr.length-1] | ||||||
|  */ |  */ | ||||||
|  | public class Selection<E> extends AbstractCustomSorts<E>{ | ||||||
|  |     @Override | ||||||
|     public void sort(E[] arr) { |     public void sort(E[] arr) { | ||||||
|         if (arr ==  null) return; |         int N=arr.length; | ||||||
|         Comparable<E>[] arr1 = (Comparable<E>[]) arr; | 
 | ||||||
|         for(int i = 0; i < arr1.length - 1; i++){ |         for(int i=0; i<N; i++){ | ||||||
|             int minIndex = i; |             int min=i; | ||||||
|             for(int j = i+1; j < arr.length; j ++){ |             for(int j=i+1; j<N; j++){ | ||||||
|                 if (less((Comparable<E>) arr[j], arr[minIndex])) minIndex = j; |                 if(less((Comparable<E>) arr[j], arr[min])) | ||||||
|  |                     min=j; | ||||||
|  |             } | ||||||
|  |             exch(arr, min, i); | ||||||
|         } |         } | ||||||
|             exch(arr, i, minIndex); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } |  | ||||||
| 
 |  | ||||||
|  | |||||||
| @ -24,33 +24,21 @@ public class Shell<E> extends AbstractCustomSorts<E> { | |||||||
|  */ |  */ | ||||||
|     @Override |     @Override | ||||||
|     public void sort(E[] arr) { |     public void sort(E[] arr) { | ||||||
|         MetaData metaData = new MetaData(); |         Insertion<E> sortingAlgorithm = new Insertion<>(); | ||||||
|         int N = arr.length; | 
 | ||||||
|         int h = 1; |         int h=1, N=arr.length; | ||||||
|         // * * Calculates the largest value of h greater than n |         while(h < N/3) | ||||||
|         while (3 * h + 1 < N) { |  | ||||||
|             h = 3*h + 1; |             h = 3*h + 1; | ||||||
|         } | 
 | ||||||
|         while( h >= 1){ |         while( h >= 1){ | ||||||
|             h = hsort(arr, h, metaData); |             sortingAlgorithm.sort(arr, h); | ||||||
|             h=h/3; |             h=h/3; | ||||||
|         } |         } | ||||||
|         System.out.println("Array sorted (shell sort) with " + metaData.compares + " compares and " + metaData.swaps + " swaps"); | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private int hsort(E[] arr, int h, MetaData metadata) { |     private int hsort(E[] arr, int h, MetaData metadata) { | ||||||
|         int N  = arr.length; |         return 0; | ||||||
|         for(int i = h; i < N; i++){ |  | ||||||
|             int j = i; |  | ||||||
|             ++metadata.compares; |  | ||||||
|             while(j >= h && less((Comparable<E>) arr[j], arr[j-h])){ |  | ||||||
|                 ++metadata.swaps; |  | ||||||
|                 exch(arr, j, j-h); |  | ||||||
|                 j = j - h; |  | ||||||
|                 ++metadata.compares; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return h; |  | ||||||
|     } |     } | ||||||
|     /* |     /* | ||||||
|      * Sample implementation of insertion sort as h-sort of h = 1 |      * Sample implementation of insertion sort as h-sort of h = 1 | ||||||
|  | |||||||
| @ -6,51 +6,91 @@ import org.junit.jupiter.api.DisplayName; | |||||||
| import org.junit.jupiter.api.Test; | import org.junit.jupiter.api.Test; | ||||||
| import com.hithomelabs.princeton1.common.Apple; | import com.hithomelabs.princeton1.common.Apple; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Collections; | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
| 
 | 
 | ||||||
|  | import static org.junit.jupiter.api.Assertions.assertEquals; | ||||||
|  | import static org.junit.jupiter.api.Assertions.assertTrue; | ||||||
|  | 
 | ||||||
| class SortTest { | class SortTest { | ||||||
| 
 | 
 | ||||||
|     private ArrayList<Apple> apples; |     private Apple[] apples, applesCopy; | ||||||
|     private AbstractCustomSorts<Apple> sortingAlgorithm; |     private AbstractCustomSorts<Apple> sortingAlgorithm; | ||||||
|     private Random random; |     private Random random; | ||||||
| 
 | 
 | ||||||
|     @BeforeEach |     @BeforeEach | ||||||
|     void setUp() { |     void setUp() { | ||||||
|         apples = new ArrayList<Apple>(); |         apples = new Apple[100]; | ||||||
|  | //        applesCopy = new Apple[100]; | ||||||
|         //sortingAlgorithm = new Selection<Apple>(); |         //sortingAlgorithm = new Selection<Apple>(); | ||||||
|         random = new Random(); |         random = new Random(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void testSort(AbstractCustomSorts<Apple> sortingAlgorithm) { |     private void testSort() { | ||||||
|         for (int i = 0; i < 100; i++) |         int value; | ||||||
|             apples.add(new Apple(random.nextInt(100))); |         for (int i = 0; i < 100; i++) { | ||||||
|  |             value = random.nextInt(100); | ||||||
|  |             apples[i] = new Apple(value); | ||||||
|  | //            applesCopy[i] = new Apple(value); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     private boolean test(){ | ||||||
|  |         for(int i=0;i<99;i++){ | ||||||
|  |             if(apples[i].compareTo(apples[i+1]) > 0) | ||||||
|  |                 return false; | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Test |     @Test | ||||||
|     @DisplayName("Testing Insertion sort functionality") |     @DisplayName("Testing Insertion sort functionality") | ||||||
|     public void testInsertionSort() { |     public void testInsertionSort() { | ||||||
|         sortingAlgorithm = new Insertion<Apple>(); |         sortingAlgorithm = new Insertion<Apple>(); | ||||||
|         testSort(sortingAlgorithm); |         //populates random apples | ||||||
|  |         testSort(); | ||||||
|  | 
 | ||||||
|  |         //calling sort function | ||||||
|  |         sortingAlgorithm.sort(apples); | ||||||
|  | 
 | ||||||
|  |         //checking if sorted array has any element which is less than preceeding one | ||||||
|  |         assertTrue(test()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     @DisplayName("Testing Selection sort functionality") |     @DisplayName("Testing Selection sort functionality") | ||||||
|     public void testSelectionSort() { |     public void testSelectionSort() { | ||||||
|         sortingAlgorithm = new Selection<Apple>(); |         sortingAlgorithm = new Selection<Apple>(); | ||||||
|         testSort(sortingAlgorithm); |         //populates random apples | ||||||
|  |         testSort(); | ||||||
|  | 
 | ||||||
|  |         //calling sort function | ||||||
|  |         sortingAlgorithm.sort(apples); | ||||||
|  | 
 | ||||||
|  |         //checking if sorted array has any element which is less than preceeding one | ||||||
|  |         assertTrue(test()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     @DisplayName("Testing Shell sort functionality") |     @DisplayName("Testing Shell sort functionality") | ||||||
|     public void testShellSort() { |     public void testShellSort() { | ||||||
|         sortingAlgorithm = new Shell<>(); |         sortingAlgorithm = new Shell<Apple>(); | ||||||
|         testSort(sortingAlgorithm); |         //populates random apples | ||||||
|  |         testSort(); | ||||||
|  | 
 | ||||||
|  |         //calling sort function | ||||||
|  |         sortingAlgorithm.sort(apples); | ||||||
|  | 
 | ||||||
|  |         //checking if sorted array has any element which is less than preceeding one | ||||||
|  |         assertTrue(test()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @AfterEach |     @AfterEach | ||||||
|     void tearDown() { |     void tearDown() { | ||||||
|         sortingAlgorithm = null; |         sortingAlgorithm = null; | ||||||
|         apples = null; |         apples = null; | ||||||
|  |         applesCopy = null; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -2,45 +2,62 @@ package com.hithomelabs.princeton1.module6; | |||||||
| 
 | 
 | ||||||
| import com.hithomelabs.princeton1.module5.AbstractCustomSorts; | import com.hithomelabs.princeton1.module5.AbstractCustomSorts; | ||||||
| 
 | 
 | ||||||
| import java.util.Arrays; | import java.util.Random; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| public class Merge<E> extends AbstractCustomSorts<E> { | public class Merge<E> extends AbstractCustomSorts<E> { | ||||||
|     @Override |     @Override | ||||||
|     public void sort(E[] arr) { |     public void sort(E[] arr) { | ||||||
| 
 |         E[] aux = (E[]) new Object[arr.length]; | ||||||
|         int N = arr.length; |         sort(arr, aux, 0, arr.length-1); | ||||||
|         // * * aux is a helper array required for merge |  | ||||||
|         E[] aux = Arrays.copyOf(arr, N); |  | ||||||
|         mergesort(arr, aux, 0, N-1); |  | ||||||
| 
 |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void mergesort(E[] arr, E[] aux, int lo, int hi) { | 
 | ||||||
|  |     private void sort(E[] arr,E[] aux, int lo, int hi){ | ||||||
| 
 | 
 | ||||||
|         if(hi<=lo) return; |         if(hi<=lo) return; | ||||||
|         int mid = lo + (hi - lo)/2; |         int mid = lo + (hi - lo)/2; | ||||||
|         mergesort(arr, aux, lo, mid); |         sort(arr,aux, lo, mid); | ||||||
|         mergesort(arr, aux, mid+1, hi); |         sort(arr,aux, mid+1,hi); | ||||||
|         merge(arr,aux,lo, mid, hi); |         merge(arr,aux,lo, mid, hi); | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void merge(E[] arr, E[] aux, int lo, int mid, int hi){ |     private void merge(E[] arr, E[] aux, int lo, int mid, int hi){ | ||||||
| 
 | 
 | ||||||
|         // * * creating backup of original array |  | ||||||
|         for (int i = lo; i <= hi; i++) |  | ||||||
|             aux[i] = arr[i]; |  | ||||||
| 
 | 
 | ||||||
|         int i = lo; |         for(int k=lo; k<=hi ;k++) | ||||||
|         int j = mid+1; |             aux[k] = arr[k]; | ||||||
|  | 
 | ||||||
|  |         int i=lo, j = mid+1; | ||||||
|  | 
 | ||||||
|         for(int k = lo; k<=hi; k++){ |         for(int k = lo; k<=hi; k++){ | ||||||
|             // * If i has already reached mid, no need to compare we insert at pointer k |  | ||||||
|             if(i>mid) arr[k] = aux[j++]; |             if(i>mid) arr[k] = aux[j++]; | ||||||
|             else if(j>hi) arr[k] = aux[i++]; |             else if(j>hi) arr[k] = aux[i++]; | ||||||
|             else if(less((Comparable<E>) aux[i], aux[j] )) arr[k] = aux[i++]; |             else if(less((Comparable<E>) aux[i], aux[j] )) arr[k] = aux[i++]; | ||||||
|             else arr[k] = aux[j++]; |             else arr[k] = aux[j++]; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  | //    public static void main(String[] args){ | ||||||
|  | //        Integer[] arrTest = new Integer[6]; | ||||||
|  | // | ||||||
|  | //        for(int i=0;i<6;i++){ | ||||||
|  | //            arrTest[i] = new Random().nextInt(100); | ||||||
|  | //            System.out.println(arrTest[i]); | ||||||
|  | //        } | ||||||
|  | // | ||||||
|  | //        System.out.println(); | ||||||
|  | // | ||||||
|  | //        Merge<Integer> sortAlgo = new Merge<>(); | ||||||
|  | // | ||||||
|  | //        sortAlgo.sort(arrTest); | ||||||
|  | // | ||||||
|  | //        for(Integer i: arrTest) | ||||||
|  | //            System.out.println(i); | ||||||
|  | //    } | ||||||
|  | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2,53 +2,57 @@ package com.hithomelabs.princeton1.module7; | |||||||
| 
 | 
 | ||||||
| import com.hithomelabs.princeton1.module5.AbstractCustomSorts; | import com.hithomelabs.princeton1.module5.AbstractCustomSorts; | ||||||
| 
 | 
 | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Collections; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| public class Quick<E> extends AbstractCustomSorts<E> { | public class Quick<E> extends AbstractCustomSorts<E> { | ||||||
|     @Override |     @Override | ||||||
|     public void sort(E[] arr) { |     public void sort(E[] arr) { | ||||||
|         int N = arr.length; | //        Collections.shuffle(Arrays.asList(arr)); | ||||||
|         quickSort(arr, 0, N - 1); |         sort(arr, 0, arr.length-1); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void altSort(E[] arr) { |     public void sort(E[] arr, int lo, int hi){ | ||||||
|         int N = arr.length; |  | ||||||
|         altQuickSort(arr, 0, N-1); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private void altQuickSort(E[] arr, int lo, int hi) { |  | ||||||
|         if(lo>=hi) return; |         if(lo>=hi) return; | ||||||
|         int i = lo + 1; |         int pivot = partition(arr, lo, hi); | ||||||
|         int j = i; |         sort(arr, lo, pivot-1); | ||||||
|         while(j <= hi){ |         sort(arr, pivot+1,hi); | ||||||
|             if(less((Comparable<E>) arr[j], arr[lo])){ |  | ||||||
|                 exch(arr, i, j); |  | ||||||
|                 i++; |  | ||||||
|             } |  | ||||||
|             j++; |  | ||||||
|         } |  | ||||||
|         exch(arr, i-1, lo); |  | ||||||
|         altQuickSort(arr, lo, i-2); |  | ||||||
|         altQuickSort(arr, i, hi); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void quickSort(E[] arr, int lo, int hi) { |     private int partition(E[] arr, int lo, int hi){ | ||||||
|  |         int pivot=lo, i=lo, j=hi+1; | ||||||
| 
 | 
 | ||||||
|         if (lo >= hi) return; |         while(i<j){ | ||||||
|         int i = lo; |              while(less((Comparable<E>) arr[++i], arr[pivot])) | ||||||
|         int j = hi+1; |  | ||||||
|         while(true){ |  | ||||||
|             while(less((Comparable<E>) arr[++i], arr[lo])){ |  | ||||||
|                  if(i == hi) break; |                  if(i == hi) break; | ||||||
|             } | 
 | ||||||
|             while(!less((Comparable<E>) arr[--j], arr[lo])){ |              while(less((Comparable<E>) arr[pivot], arr[--j])) | ||||||
|                  if(j == lo) break; |                  if(j == lo) break; | ||||||
|             } | 
 | ||||||
|             if(j<=i) break; |              if(i>=j) break; | ||||||
|              exch(arr,i, j); |              exch(arr,i, j); | ||||||
|         } |         } | ||||||
|         exch(arr, j, lo); |         exch(arr,pivot,j); | ||||||
|         quickSort(arr, lo, j-1); |         return j; | ||||||
|         quickSort(arr, j+1, hi); |     } | ||||||
| 
 | 
 | ||||||
|     } | //        public static void main(String[] args){ | ||||||
|  | //        Integer[] arrTest = new Integer[6]; | ||||||
|  | // | ||||||
|  | //        for(int i=0;i<6;i++){ | ||||||
|  | //            arrTest[i] = new Random().nextInt(100); | ||||||
|  | //            System.out.println(arrTest[i]); | ||||||
|  | //        } | ||||||
|  | // | ||||||
|  | //        System.out.println(); | ||||||
|  | // | ||||||
|  | //        Quick<Integer> sortAlgo = new Quick<>(); | ||||||
|  | // | ||||||
|  | //        sortAlgo.sort(arrTest); | ||||||
|  | // | ||||||
|  | //        for(Integer i: arrTest) | ||||||
|  | //            System.out.println(i); | ||||||
|  | //    } | ||||||
| } | } | ||||||
|  | |||||||
| @ -33,6 +33,8 @@ class QuickTest { | |||||||
|         Assertions.assertArrayEquals(sorted, arr); |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // * * Optional test for alternate sort implmentation | ||||||
|  |     /* | ||||||
|     @Test |     @Test | ||||||
|     @DisplayName("testing Quick sort default implementation") |     @DisplayName("testing Quick sort default implementation") | ||||||
|     public void testAltSort(){ |     public void testAltSort(){ | ||||||
| @ -45,6 +47,8 @@ class QuickTest { | |||||||
|         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|         Assertions.assertArrayEquals(sorted, arr); |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|     } |     } | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     @AfterEach |     @AfterEach | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								module8/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								module8/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | group = 'com.hithomelabs.princeton1.module8' | ||||||
|  | version = 'unspecified' | ||||||
|  | 
 | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | dependencies { | ||||||
|  |     testImplementation platform('org.junit:junit-bom:5.10.0') | ||||||
|  |     testImplementation 'org.junit.jupiter:junit-jupiter' | ||||||
|  |     implementation project(':module5') | ||||||
|  |     testImplementation project(':common') | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | test { | ||||||
|  |     useJUnitPlatform() | ||||||
|  | } | ||||||
| @ -0,0 +1,35 @@ | |||||||
|  | package com.hithomelabs.princeton1.module8; | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  |  * * Designing Heap as a wrapper class with static methods that perform sink and swim operations on underlying comparable[] array | ||||||
|  |  * * Heap does not have any instance variables, instance variables shall be housed by, the implementation using heaps, like priority queues and heap sort | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.AbstractCustomSorts; | ||||||
|  | 
 | ||||||
|  | public class Heap{ | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     * * Sink Node T with to it's appropriate place in a Heap of size N, if it's children exist and are greater | ||||||
|  |     * * Implement sink API to sink a node if it's sub-heap is not heap-order | ||||||
|  |     */ | ||||||
|  |     public static <T> void sink(T[] arr, int root, int N){ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // * * Swim if element is not root, and parent is lesser than node | ||||||
|  |     public static <T extends Comparable<T>> void swim(T[] arr, int node, int N){ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private static <T> void exch(T[] arr, int i, int j){ | ||||||
|  |         T temp = arr[i]; | ||||||
|  |         arr[i] = arr[j]; | ||||||
|  |         arr[j] = temp; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private static <T> boolean less(T v, T w){ | ||||||
|  |         if(((Comparable<T>)v).compareTo(w) < 1 ) return true; | ||||||
|  |         else return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,27 @@ | |||||||
|  | package com.hithomelabs.princeton1.module8; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.AbstractCustomSorts; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | public class HeapSort<E> extends AbstractCustomSorts<E> { | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         int N = arr.length; | ||||||
|  | 
 | ||||||
|  |         E[] heapArr = (E[]) new Object[N+1]; | ||||||
|  |         // * * to simplify we copy original array and write it to the new array starting index 1 | ||||||
|  |         System.arraycopy(arr, 0, heapArr, 1, N); | ||||||
|  |         // * * An array of size N holds a heap of size N-1 | ||||||
|  |         coreSortingLogic(heapArr, N); | ||||||
|  |         // * * Re-copying the sorted array to the original | ||||||
|  |         System.arraycopy(heapArr, 1, arr, 0, N); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |      * * Implement the core sorting logic | ||||||
|  |      * * P.S the provision of making the index 0 null for ease of use has already been done above | ||||||
|  |     */ | ||||||
|  |     private void coreSortingLogic(E[] arr, int N) { | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,51 @@ | |||||||
|  | package com.hithomelabs.princeton1.module8; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import org.junit.jupiter.api.*; | ||||||
|  | 
 | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  | 
 | ||||||
|  | class HeapSortTest { | ||||||
|  | 
 | ||||||
|  |     private HeapSort<Apple> heap; | ||||||
|  |     private ArrayList<Apple> apples; | ||||||
|  |     private Random random; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         heap = new HeapSort<Apple>(); | ||||||
|  |         apples = new ArrayList<Apple>(); | ||||||
|  |         random = new Random(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Sort a heap of a 100 random sized apples") | ||||||
|  |     public void testSort(){ | ||||||
|  |         for(int i = 0; i < 100; i++) | ||||||
|  |             apples.add(new Apple(random.nextInt(1000))); | ||||||
|  |         Apple[] arr = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         heap.sort(arr); | ||||||
|  |         apples.sort(null); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Sort 100 apples in descending order") | ||||||
|  |     public void testSortBorder(){ | ||||||
|  |         for(int i = 0; i < 100; i++) | ||||||
|  |             apples.add(new Apple(100 - i)); | ||||||
|  |         Apple[] arr = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         heap.sort(arr); | ||||||
|  |         apples.sort(null); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -17,4 +17,5 @@ include 'module5' | |||||||
| include 'module6' | include 'module6' | ||||||
| include 'common' | include 'common' | ||||||
| include 'module7' | include 'module7' | ||||||
|  | include 'module8' | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user