forked from Hithomelabs/Princeton1
		
	Compare commits
	
		
			11 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 38de5fe0a5 | |||
| 8c47ac248c | |||
| bbc040dcd4 | |||
| 6a752c9dc2 | |||
| 90f8b14ee5 | |||
| 178f0461ee | |||
| a4ccbee99c | |||
| 3c3eee2e4d | |||
| f0b577b5f6 | |||
| 7ba2d22e43 | |||
| fdca30f50a | 
| @ -16,7 +16,7 @@ jobs: | |||||||
|         uses: actions/setup-java@v4 |         uses: actions/setup-java@v4 | ||||||
|         with: |         with: | ||||||
|           distribution: 'zulu' |           distribution: 'zulu' | ||||||
|           java-version: '21' |           java-version: '11' | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/actions/wrapper-validation@v3 |         uses: gradle/actions/wrapper-validation@v3 | ||||||
|       - name: Gradle build |       - name: Gradle build | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -3,3 +3,4 @@ | |||||||
| 
 | 
 | ||||||
| # Ignore Gradle build output directory | # Ignore Gradle build output directory | ||||||
| build | build | ||||||
|  | bin | ||||||
							
								
								
									
										4
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
								
							| @ -9,7 +9,11 @@ | |||||||
|           <set> |           <set> | ||||||
|             <option value="$PROJECT_DIR$" /> |             <option value="$PROJECT_DIR$" /> | ||||||
|             <option value="$PROJECT_DIR$/clients" /> |             <option value="$PROJECT_DIR$/clients" /> | ||||||
|  |             <option value="$PROJECT_DIR$/common" /> | ||||||
|             <option value="$PROJECT_DIR$/module4" /> |             <option value="$PROJECT_DIR$/module4" /> | ||||||
|  |             <option value="$PROJECT_DIR$/module5" /> | ||||||
|  |             <option value="$PROJECT_DIR$/module6" /> | ||||||
|  |             <option value="$PROJECT_DIR$/module7" /> | ||||||
|           </set> |           </set> | ||||||
|         </option> |         </option> | ||||||
|       </GradleProjectSettings> |       </GradleProjectSettings> | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								.idea/modules.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.idea/modules.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="ProjectModuleManager"> | ||||||
|  |     <modules> | ||||||
|  |       <module fileurl="file://$PROJECT_DIR$/.idea/modules/module4/Pricenton1.module4.test.iml" filepath="$PROJECT_DIR$/.idea/modules/module4/Pricenton1.module4.test.iml" /> | ||||||
|  |     </modules> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										8
									
								
								.idea/modules/module4/Pricenton1.module4.test.iml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.idea/modules/module4/Pricenton1.module4.test.iml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <module version="4"> | ||||||
|  |   <component name="AdditionalModuleElements"> | ||||||
|  |     <content url="file://$MODULE_DIR$/../../../module4/src/test" dumb="true"> | ||||||
|  |       <sourceFolder url="file://$MODULE_DIR$/../../../module4/src/test/java" isTestSource="true" /> | ||||||
|  |     </content> | ||||||
|  |   </component> | ||||||
|  | </module> | ||||||
							
								
								
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @ -1,4 +1,8 @@ | |||||||
| { | { | ||||||
|     "java.compile.nullAnalysis.mode": "automatic", |     "java.compile.nullAnalysis.mode": "automatic", | ||||||
|     "jdk.java.onSave.organizeImports": true |     "jdk.java.onSave.organizeImports": true, | ||||||
|  |     "java.configuration.updateBuildConfiguration": "interactive", | ||||||
|  |     "cSpell.words": [ | ||||||
|  |         "hithomelabs" | ||||||
|  |     ] | ||||||
| } | } | ||||||
| @ -1,10 +1,18 @@ | |||||||
| #Data Structures | # Data Structures | ||||||
| 
 | 
 | ||||||
|     1. Stacks: | 1. Stacks: | ||||||
|  |    - [API](../module4/src/main/java/com/hithomelabs/princeton1/module4/Stack.java) | ||||||
|  |    - [Sample client](../clients/src/main/java/com/hithomelabs/clients/ArrayStackClient.java) | ||||||
|    - Linear data structure |    - Linear data structure | ||||||
|    - Can have various implementations |    - Can have various implementations | ||||||
|    - Should support (LIFO) |    - Should support (LIFO) | ||||||
|         - Primitive implementation (Using arrays of primitive data types) |    - [Primitive implementation](../module4/src/main/java/com/hithomelabs/princeton1/module4/ArrayStack.java) (Using arrays of primitive data types) | ||||||
|         - Other implementations (Using linked lists) |    - [Other implementations](../module4/src/main/java/com/hithomelabs/princeton1/module4/LinkedStack.java) (Using linked lists) | ||||||
|     2. Queues: | 2. Queues: | ||||||
|          |    - [API](../module4/src/main/java/com/hithomelabs/princeton1/module4/Queue.java) | ||||||
|  |    - [sample Client](../clients/src/main/java/com/hithomelabs/clients/LinkedQueueClient.java) | ||||||
|  |    - Linear data structure. | ||||||
|  |    - Can have various implementations. | ||||||
|  |    - Should support FIFO. | ||||||
|  |    - [Primitive implementation](../module4/src/main/java/com/hithomelabs/princeton1/module4/ArrayQueue.java) (Using array of primitive data types) | ||||||
|  |    - Other implementation ([using linked lists](../module4/src/main/java/com/hithomelabs/princeton1/module4/LinkedQueue.java)) | ||||||
							
								
								
									
										125
									
								
								Roadmaps/sorts.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								Roadmaps/sorts.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,125 @@ | |||||||
|  | ### Sorting an array of size (n) : 32 | ||||||
|  | n^2 for this array is : 1024.0<br> | ||||||
|  | nlogn for this array is : 160.0 | ||||||
|  | 
 | ||||||
|  | | ARRAY NATURE | ALGORITHM | TIME ELAPSED (ns) | COMPARES | EXCHANGES | | ||||||
|  | |--|--|--|--|--| | ||||||
|  | | ALREADY SORTED | Selection Sort | 146007.0 | 496.0 | 31.0 | | ||||||
|  | | ALREADY SORTED | Insertion Sort | 18685.0 | 31.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Shell Sort | 10791.0 | 78.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Merge Sort | 56837.0 | 160.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Quick Sort | 44935.0 | 558.0 | 31.0 | | ||||||
|  | | ALREADY SORTED | Three Way Quick Sort | 84400.0 | 357.0 | 195.0 | | ||||||
|  | | ALREADY SORTED | Heap Sort | 35678.0 | 231.0 | 146.0 | | ||||||
|  | | PARTIALLY SORTED | Selection Sort | 31420.0 | 496.0 | 31.0 | | ||||||
|  | | PARTIALLY SORTED | Insertion Sort | 10620.0 | 100.0 | 70.0 | | ||||||
|  | | PARTIALLY SORTED | Shell Sort | 12814.0 | 121.0 | 48.0 | | ||||||
|  | | PARTIALLY SORTED | Merge Sort | 28103.0 | 160.0 | 0.0 | | ||||||
|  | | PARTIALLY SORTED | Quick Sort | 17834.0 | 187.0 | 30.0 | | ||||||
|  | | PARTIALLY SORTED | Three Way Quick Sort | 53461.0 | 240.0 | 145.0 | | ||||||
|  | | PARTIALLY SORTED | Heap Sort | 10079.0 | 226.0 | 142.0 | | ||||||
|  | | REVERSE SORTED | Selection Sort | 31490.0 | 496.0 | 31.0 | | ||||||
|  | | REVERSE SORTED | Insertion Sort | 51979.0 | 496.0 | 496.0 | | ||||||
|  | | REVERSE SORTED | Shell Sort | 19998.0 | 114.0 | 58.0 | | ||||||
|  | | REVERSE SORTED | Merge Sort | 24306.0 | 160.0 | 0.0 | | ||||||
|  | | REVERSE SORTED | Quick Sort | 38042.0 | 542.0 | 31.0 | | ||||||
|  | | REVERSE SORTED | Three Way Quick Sort | 55355.0 | 496.0 | 496.0 | | ||||||
|  | | REVERSE SORTED | Heap Sort | 8726.0 | 202.0 | 112.0 | | ||||||
|  | | RANDOMLY ORDERED | Selection Sort | 38714.0 | 496.0 | 31.0 | | ||||||
|  | | RANDOMLY ORDERED | Insertion Sort | 28294.0 | 282.0 | 255.0 | | ||||||
|  | | RANDOMLY ORDERED | Shell Sort | 15409.0 | 152.0 | 89.0 | | ||||||
|  | | RANDOMLY ORDERED | Merge Sort | 25057.0 | 160.0 | 0.0 | | ||||||
|  | | RANDOMLY ORDERED | Quick Sort | 18345.0 | 228.0 | 37.0 | | ||||||
|  | | RANDOMLY ORDERED | Three Way Quick Sort | 27702.0 | 229.0 | 157.0 | | ||||||
|  | | RANDOMLY ORDERED | Heap Sort | 9458.0 | 218.0 | 133.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Selection Sort | 32061.0 | 496.0 | 31.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Insertion Sort | 21601.0 | 213.0 | 183.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Shell Sort | 11792.0 | 118.0 | 50.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Merge Sort | 26440.0 | 160.0 | 0.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Quick Sort | 17994.0 | 203.0 | 38.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Three Way Quick Sort | 17162.0 | 192.0 | 80.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Heap Sort | 9138.0 | 223.0 | 128.0 | | ||||||
|  | 
 | ||||||
|  | ### Sorting an array of size (n) : 512 | ||||||
|  | n^2 for this array is : 262144.0<br> | ||||||
|  | nlogn for this array is : 4608.0 | ||||||
|  | 
 | ||||||
|  | | ARRAY NATURE | ALGORITHM | TIME ELAPSED (ns) | COMPARES | EXCHANGES | | ||||||
|  | |--|--|--|--|--| | ||||||
|  | | ALREADY SORTED | Selection Sort | 4850717.0 | 130816.0 | 511.0 | | ||||||
|  | | ALREADY SORTED | Insertion Sort | 35989.0 | 511.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Shell Sort | 158500.0 | 2529.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Merge Sort | 449562.0 | 4608.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Quick Sort | 3002463.0 | 131838.0 | 511.0 | | ||||||
|  | | ALREADY SORTED | Three Way Quick Sort | 1673142.0 | 25227.0 | 13149.0 | | ||||||
|  | | ALREADY SORTED | Heap Sort | 254052.0 | 7958.0 | 4464.0 | | ||||||
|  | | PARTIALLY SORTED | Selection Sort | 1965597.0 | 130816.0 | 511.0 | | ||||||
|  | | PARTIALLY SORTED | Insertion Sort | 2597005.0 | 29114.0 | 28607.0 | | ||||||
|  | | PARTIALLY SORTED | Shell Sort | 425297.0 | 5355.0 | 2949.0 | | ||||||
|  | | PARTIALLY SORTED | Merge Sort | 298236.0 | 4608.0 | 0.0 | | ||||||
|  | | PARTIALLY SORTED | Quick Sort | 188748.0 | 6429.0 | 952.0 | | ||||||
|  | | PARTIALLY SORTED | Three Way Quick Sort | 300219.0 | 9526.0 | 5537.0 | | ||||||
|  | | PARTIALLY SORTED | Heap Sort | 221880.0 | 7689.0 | 4266.0 | | ||||||
|  | | REVERSE SORTED | Selection Sort | 1964334.0 | 130816.0 | 511.0 | | ||||||
|  | | REVERSE SORTED | Insertion Sort | 8566013.0 | 130816.0 | 130816.0 | | ||||||
|  | | REVERSE SORTED | Shell Sort | 501150.0 | 4098.0 | 1790.0 | | ||||||
|  | | REVERSE SORTED | Merge Sort | 133242.0 | 4608.0 | 0.0 | | ||||||
|  | | REVERSE SORTED | Quick Sort | 2777496.0 | 131582.0 | 511.0 | | ||||||
|  | | REVERSE SORTED | Three Way Quick Sort | 4018770.0 | 130816.0 | 130816.0 | | ||||||
|  | | REVERSE SORTED | Heap Sort | 316731.0 | 7203.0 | 3772.0 | | ||||||
|  | | RANDOMLY ORDERED | Selection Sort | 2139577.0 | 130816.0 | 511.0 | | ||||||
|  | | RANDOMLY ORDERED | Insertion Sort | 1740760.0 | 66207.0 | 65704.0 | | ||||||
|  | | RANDOMLY ORDERED | Shell Sort | 845052.0 | 5834.0 | 3503.0 | | ||||||
|  | | RANDOMLY ORDERED | Merge Sort | 170153.0 | 4608.0 | 0.0 | | ||||||
|  | | RANDOMLY ORDERED | Quick Sort | 137871.0 | 5685.0 | 1068.0 | | ||||||
|  | | RANDOMLY ORDERED | Three Way Quick Sort | 266034.0 | 6785.0 | 4434.0 | | ||||||
|  | | RANDOMLY ORDERED | Heap Sort | 304848.0 | 7658.0 | 4172.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Selection Sort | 5186584.0 | 130816.0 | 511.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Insertion Sort | 1422557.0 | 57576.0 | 57067.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Shell Sort | 432791.0 | 4097.0 | 1723.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Merge Sort | 154453.0 | 4608.0 | 0.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Quick Sort | 278238.0 | 15531.0 | 906.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Three Way Quick Sort | 63401.0 | 2489.0 | 969.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Heap Sort | 280381.0 | 7212.0 | 3819.0 | | ||||||
|  | 
 | ||||||
|  | ### Sorting an array of size (n) : 1024 | ||||||
|  | n^2 for this array is : 1048576.0<br> | ||||||
|  | nlogn for this array is : 10240.0 | ||||||
|  | 
 | ||||||
|  | | ARRAY NATURE | ALGORITHM | TIME ELAPSED (ns) | COMPARES | EXCHANGES | | ||||||
|  | |--|--|--|--|--| | ||||||
|  | | ALREADY SORTED | Selection Sort | 7498749.0 | 523776.0 | 1023.0 | | ||||||
|  | | ALREADY SORTED | Insertion Sort | 22482.0 | 1023.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Shell Sort | 311771.0 | 5601.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Merge Sort | 276915.0 | 10240.0 | 0.0 | | ||||||
|  | | ALREADY SORTED | Quick Sort | 6711786.0 | 525822.0 | 1023.0 | | ||||||
|  | | ALREADY SORTED | Three Way Quick Sort | 3649069.0 | 70999.0 | 36808.0 | | ||||||
|  | | ALREADY SORTED | Heap Sort | 546827.0 | 18060.0 | 9968.0 | | ||||||
|  | | PARTIALLY SORTED | Selection Sort | 5672566.0 | 523776.0 | 1023.0 | | ||||||
|  | | PARTIALLY SORTED | Insertion Sort | 1121306.0 | 119251.0 | 118229.0 | | ||||||
|  | | PARTIALLY SORTED | Shell Sort | 888765.0 | 12869.0 | 7515.0 | | ||||||
|  | | PARTIALLY SORTED | Merge Sort | 998493.0 | 10240.0 | 0.0 | | ||||||
|  | | PARTIALLY SORTED | Quick Sort | 220528.0 | 13342.0 | 2143.0 | | ||||||
|  | | PARTIALLY SORTED | Three Way Quick Sort | 1015716.0 | 18425.0 | 10928.0 | | ||||||
|  | | PARTIALLY SORTED | Heap Sort | 412432.0 | 17351.0 | 9501.0 | | ||||||
|  | | REVERSE SORTED | Selection Sort | 5445486.0 | 523776.0 | 1023.0 | | ||||||
|  | | REVERSE SORTED | Insertion Sort | 4216956.0 | 523776.0 | 523776.0 | | ||||||
|  | | REVERSE SORTED | Shell Sort | 618302.0 | 9175.0 | 4430.0 | | ||||||
|  | | REVERSE SORTED | Merge Sort | 923041.0 | 10240.0 | 0.0 | | ||||||
|  | | REVERSE SORTED | Quick Sort | 7040860.0 | 525310.0 | 1023.0 | | ||||||
|  | | REVERSE SORTED | Three Way Quick Sort | 3.3696654E7 | 523776.0 | 523776.0 | | ||||||
|  | | REVERSE SORTED | Heap Sort | 374319.0 | 16407.0 | 8542.0 | | ||||||
|  | | RANDOMLY ORDERED | Selection Sort | 538151.0 | 523776.0 | 1023.0 | | ||||||
|  | | RANDOMLY ORDERED | Insertion Sort | 2208077.0 | 263988.0 | 262976.0 | | ||||||
|  | | RANDOMLY ORDERED | Shell Sort | 985999.0 | 13931.0 | 8766.0 | | ||||||
|  | | RANDOMLY ORDERED | Merge Sort | 1100978.0 | 10240.0 | 0.0 | | ||||||
|  | | RANDOMLY ORDERED | Quick Sort | 244102.0 | 13790.0 | 2377.0 | | ||||||
|  | | RANDOMLY ORDERED | Three Way Quick Sort | 911649.0 | 16118.0 | 10074.0 | | ||||||
|  | | RANDOMLY ORDERED | Heap Sort | 414616.0 | 17306.0 | 9311.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Selection Sort | 536507.0 | 523776.0 | 1023.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Insertion Sort | 1991185.0 | 241533.0 | 240512.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Shell Sort | 561314.0 | 8621.0 | 3374.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Merge Sort | 990428.0 | 10240.0 | 0.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Quick Sort | 746566.0 | 59026.0 | 1844.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Three Way Quick Sort | 229926.0 | 4749.0 | 1894.0 | | ||||||
|  | | FEW FREQUENTLY OCCURING | Heap Sort | 172988.0 | 16171.0 | 8449.0 | | ||||||
| @ -13,6 +13,17 @@ dependencies { | |||||||
|     testImplementation platform('org.junit:junit-bom:5.10.0') |     testImplementation platform('org.junit:junit-bom:5.10.0') | ||||||
|     testImplementation 'org.junit.jupiter:junit-jupiter' |     testImplementation 'org.junit.jupiter:junit-jupiter' | ||||||
|     implementation project(':module4') |     implementation project(':module4') | ||||||
|  |     implementation project(':module5') | ||||||
|  |     implementation project(':module6') | ||||||
|  |     implementation project(':module7') | ||||||
|  |     implementation project(':module8') | ||||||
|  |     implementation project(':common') | ||||||
|  |     testImplementation project(':common') | ||||||
|  | } | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(11) | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| test { | test { | ||||||
|  | |||||||
| @ -0,0 +1,30 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks; | ||||||
|  | 
 | ||||||
|  | public class ArraySize { | ||||||
|  | 
 | ||||||
|  |     private final int size; | ||||||
|  |     public ArraySize(int n){ | ||||||
|  |         size = n; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int getSize() { | ||||||
|  |         return size; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public double getNSquare(){ | ||||||
|  |         return Math.pow(size,2); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public double getNlogN(){ | ||||||
|  |         return size * Math.log(size)/ Math.log(2); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public double getLogN(){ | ||||||
|  |         return Math.log(size)/ Math.log(2); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "### Sorting an array of size (n) : " + getSize() + " \n" + "n^2 for this array is : " + getNSquare() + "<br> \n" + "nlogn for this array is : " + getNlogN() + "\n"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,47 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.clients.Benchmarks.Sortables.*; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.List; | ||||||
|  | 
 | ||||||
|  | public class BenchMark { | ||||||
|  | 
 | ||||||
|  |     private ArraySize size; | ||||||
|  |     private List<MeasurableSort<Apple>> algorithms; | ||||||
|  |     private List<Sortable<Apple>> sortableCollections; | ||||||
|  |     private static final String header = "| ARRAY NATURE | ALGORITHM | TIME ELAPSED (ns) | COMPARES | EXCHANGES |"; | ||||||
|  |     // * Helps get a table in markdown | ||||||
|  |     private static final String markdownTableFormatter = "|--|--|--|--|--|"; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     BenchMark(int size, List<MeasurableSort<Apple>> algorithms) { | ||||||
|  |         this.size = new ArraySize(size); | ||||||
|  |         this.algorithms = algorithms; | ||||||
|  |         sortableCollections = new ArrayList<Sortable<Apple>>(); | ||||||
|  |         sortableCollections.add(new AlreadySortedApples(size)); | ||||||
|  |         sortableCollections.add(new PartiallySortedApples(size, 1000)); | ||||||
|  |         sortableCollections.add(new ReverseSortedApples(size)); | ||||||
|  |         sortableCollections.add(new RandomlySizedApples(size, 1000)); | ||||||
|  |         sortableCollections.add(new FewFrequentlyOccuringApples(size)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void run() { | ||||||
|  | 
 | ||||||
|  |         System.out.println(size); | ||||||
|  |         System.out.println(header); | ||||||
|  |         System.out.println(markdownTableFormatter); | ||||||
|  |         for(Sortable<Apple> array: sortableCollections){ | ||||||
|  |             new Bundle<Apple>(array, algorithms).run(Apple.COMPARE_BY_SIZE); | ||||||
|  |         } | ||||||
|  |         System.out.println(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,41 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module5.Insertion; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.Selection; | ||||||
|  | import com.hithomelabs.princeton1.module5.Shell; | ||||||
|  | import com.hithomelabs.princeton1.module6.Merge; | ||||||
|  | import com.hithomelabs.princeton1.module7.Quick; | ||||||
|  | import com.hithomelabs.princeton1.module7.ThreeWayQuick; | ||||||
|  | import com.hithomelabs.princeton1.module8.HeapSort; | ||||||
|  | 
 | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.List; | ||||||
|  | 
 | ||||||
|  | public class BenchMarkingClient { | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args) { | ||||||
|  |         List<MeasurableSort<Apple>> algorithms = new ArrayList<MeasurableSort<Apple>>(); | ||||||
|  | 
 | ||||||
|  |         algorithms.add(new Selection<Apple>()); | ||||||
|  |         algorithms.add(new Insertion<Apple>()); | ||||||
|  |         algorithms.add(new Shell<Apple>()); | ||||||
|  |         algorithms.add(new Merge<Apple>()); | ||||||
|  |         algorithms.add(new Quick<Apple>()); | ||||||
|  |         algorithms.add(new ThreeWayQuick<Apple>()); | ||||||
|  |         algorithms.add(new HeapSort<Apple>()); | ||||||
|  | 
 | ||||||
|  |         BenchMark b1 = new BenchMark(32, algorithms); | ||||||
|  |         BenchMark b2 = new BenchMark(512, algorithms); | ||||||
|  |         BenchMark b3 = new BenchMark(1024, algorithms); | ||||||
|  |         BenchMark b4 = new BenchMark(4096,algorithms); | ||||||
|  |         //b1.run(); | ||||||
|  |         //b2.run(); | ||||||
|  |         //b3.run(); | ||||||
|  |         b4.run(); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,38 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.SortingMetaData; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | import java.util.List; | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  | * * A sorting bundle, that bundles one array and passes a copy of that array for all algorithms to sort | ||||||
|  |  */ | ||||||
|  | public class Bundle<E> { | ||||||
|  | 
 | ||||||
|  |     private Sortable<E> array; | ||||||
|  |     private List<MeasurableSort<E>> algorithms; | ||||||
|  |     private Comparator<E> cmp; | ||||||
|  | 
 | ||||||
|  |     Bundle(Sortable<E> array, List<MeasurableSort<E>> algorithms){ | ||||||
|  |         this.array = array; | ||||||
|  |         this.algorithms = algorithms; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     Bundle (Sortable<E> array, List<MeasurableSort<E>> algorithms, Comparator<E> cmp){ | ||||||
|  |         this(array, algorithms); | ||||||
|  |         if (cmp != null) this.cmp = cmp; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void run(Comparator<E> cmp){ | ||||||
|  |         for (MeasurableSort<E> sortingAlgorithm: algorithms){ | ||||||
|  |             SortingMetaData metaData = new SortingMetaData(); | ||||||
|  |             sortingAlgorithm.sort(array.getArray(), cmp, metaData); | ||||||
|  |             System.out.println("| " + array.getOrdering() + " | " + sortingAlgorithm + " | " + metaData.timeElapsed() + " | "  + metaData.getCompares() + " | " + metaData.getExchanges() + " |" ); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks; | ||||||
|  | 
 | ||||||
|  | public interface Sortable<E> { | ||||||
|  | 
 | ||||||
|  |     public E[] getArray(); | ||||||
|  | 
 | ||||||
|  |     public String getOrdering(); | ||||||
|  | } | ||||||
| @ -0,0 +1,25 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks.Sortables; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.clients.Benchmarks.Sortable; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | 
 | ||||||
|  | public class AlreadySortedApples implements Sortable<Apple> { | ||||||
|  | 
 | ||||||
|  |     Apple[] apples; | ||||||
|  | 
 | ||||||
|  |     public AlreadySortedApples(int size){ | ||||||
|  |         apples = new Apple[size]; | ||||||
|  |         for (int i = 0; i < size; i++) | ||||||
|  |             apples[i] = new Apple(i); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Apple[] getArray() { | ||||||
|  |         return apples.clone(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getOrdering() { | ||||||
|  |         return "ALREADY SORTED"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,30 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks.Sortables; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.clients.Benchmarks.Sortable; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | 
 | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class FewFrequentlyOccuringApples implements Sortable<Apple> { | ||||||
|  | 
 | ||||||
|  |     Apple[] apples; | ||||||
|  |     Random random; | ||||||
|  |     private static final int DEFAULT_SIZE_RANGE = 10; | ||||||
|  | 
 | ||||||
|  |     public FewFrequentlyOccuringApples(int size){ | ||||||
|  |         random = new Random(); | ||||||
|  |         apples = new Apple[size]; | ||||||
|  |         for (int i = 0; i < size; i++) | ||||||
|  |             apples[i] = new Apple(random.nextInt(DEFAULT_SIZE_RANGE)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Apple[] getArray() { | ||||||
|  |         return apples.clone(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getOrdering() { | ||||||
|  |         return "FEW FREQUENTLY OCCURING"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,34 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks.Sortables; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.clients.Benchmarks.Sortable; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module5.ComparableHelper; | ||||||
|  | import com.hithomelabs.princeton1.module8.HeapSort; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class PartiallySortedApples implements Sortable<Apple>, ComparableHelper { | ||||||
|  | 
 | ||||||
|  |     Apple[] apples; | ||||||
|  |     Random random; | ||||||
|  | 
 | ||||||
|  |     public PartiallySortedApples(int size, int sizeRange){ | ||||||
|  |         random = new Random(); | ||||||
|  |         apples = new Apple[size]; | ||||||
|  |         for (int i = 0; i < size; i++) | ||||||
|  |             apples[i] = new Apple(random.nextInt(sizeRange)); | ||||||
|  |         HeapSort.heapify(apples); | ||||||
|  |         int N = apples.length; | ||||||
|  |         for (int i = 0; i < N/2; i++) | ||||||
|  |             ComparableHelper.exch(apples, i, N-i-1); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Apple[] getArray() { | ||||||
|  |         return apples.clone(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getOrdering() { | ||||||
|  |         return "PARTIALLY SORTED"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,30 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks.Sortables; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.clients.Benchmarks.Sortable; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | 
 | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class RandomlySizedApples implements Sortable<Apple> { | ||||||
|  | 
 | ||||||
|  |     Apple[] apples; | ||||||
|  |     Random random; | ||||||
|  | 
 | ||||||
|  |     public RandomlySizedApples(int size, int sizeRange){ | ||||||
|  |         random = new Random(); | ||||||
|  |         apples = new Apple[size]; | ||||||
|  |         for (int i = 0; i < size; i++) | ||||||
|  |             apples[i] = new Apple(random.nextInt(sizeRange)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Apple[] getArray() { | ||||||
|  |         return apples.clone(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getOrdering() { | ||||||
|  |         return "RANDOMLY ORDERED"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,25 @@ | |||||||
|  | package com.hithomelabs.clients.Benchmarks.Sortables; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.clients.Benchmarks.Sortable; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | 
 | ||||||
|  | public class ReverseSortedApples implements Sortable<Apple> { | ||||||
|  | 
 | ||||||
|  |     Apple[] apples; | ||||||
|  | 
 | ||||||
|  |     public ReverseSortedApples(int size){ | ||||||
|  |         apples = new Apple[size]; | ||||||
|  |         for (int i = 0; i < size; i++) | ||||||
|  |             apples[i] = new Apple(size-i); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Apple[] getArray() { | ||||||
|  |         return apples.clone(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getOrdering() { | ||||||
|  |         return "REVERSE SORTED"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,4 +1,4 @@ | |||||||
| package com.hithomelabs.clients; | package com.hithomelabs.clients.module4; | ||||||
| 
 | 
 | ||||||
| import com.hithomelabs.princeton1.module4.ArrayQueue; | import com.hithomelabs.princeton1.module4.ArrayQueue; | ||||||
| import com.hithomelabs.princeton1.module4.Queue; | import com.hithomelabs.princeton1.module4.Queue; | ||||||
| @ -1,4 +1,4 @@ | |||||||
| package com.hithomelabs.clients; | package com.hithomelabs.clients.module4; | ||||||
| 
 | 
 | ||||||
| import com.hithomelabs.princeton1.module4.ArrayStack; | import com.hithomelabs.princeton1.module4.ArrayStack; | ||||||
| import com.hithomelabs.princeton1.module4.Stack; | import com.hithomelabs.princeton1.module4.Stack; | ||||||
| @ -1,4 +1,4 @@ | |||||||
| package com.hithomelabs.clients; | package com.hithomelabs.clients.module4; | ||||||
| 
 | 
 | ||||||
| import com.hithomelabs.princeton1.module4.LinkedQueue; | import com.hithomelabs.princeton1.module4.LinkedQueue; | ||||||
| import com.hithomelabs.princeton1.module4.Queue; | import com.hithomelabs.princeton1.module4.Queue; | ||||||
| @ -1,4 +1,4 @@ | |||||||
| package com.hithomelabs.clients; | package com.hithomelabs.clients.module4; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| import com.hithomelabs.princeton1.module4.LinkedStack; | import com.hithomelabs.princeton1.module4.LinkedStack; | ||||||
| @ -0,0 +1,28 @@ | |||||||
|  | package com.hithomelabs.clients.module5; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.Insertion; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.common.Orange; | ||||||
|  | 
 | ||||||
|  | public class InsertionClient { | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args){ | ||||||
|  | 
 | ||||||
|  |         Apple[] apples = new Apple[3]; | ||||||
|  |         Orange[] oranges = new Orange[3]; | ||||||
|  |         Insertion<Apple> insertion = new Insertion<>(); | ||||||
|  | 
 | ||||||
|  |         apples[0] = new Apple(3); | ||||||
|  |         apples[1] = new Apple(5); | ||||||
|  |         apples[2] = new Apple(4); | ||||||
|  |         insertion.sort(apples); | ||||||
|  | 
 | ||||||
|  |         //* * Sample output | ||||||
|  |         for (int i = 0; i < apples.length; i++) | ||||||
|  |             System.out.println(apples[i]); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,66 @@ | |||||||
|  | package com.hithomelabs.clients.module5; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.Selection; | ||||||
|  | 
 | ||||||
|  | import java.util.ArrayList; | ||||||
|  | 
 | ||||||
|  | public class SelectionClient { | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args){ | ||||||
|  | 
 | ||||||
|  |         Apple[] apples = new Apple[3]; | ||||||
|  |         Orange[] oranges = new Orange[3]; | ||||||
|  |         Selection<Apple> selection = new Selection<Apple>(); | ||||||
|  | 
 | ||||||
|  |         apples[0] = new Apple(3); | ||||||
|  |         apples[1] = new Apple(5); | ||||||
|  |         apples[2] = new Apple(4); | ||||||
|  |         selection.sort(apples); | ||||||
|  | 
 | ||||||
|  |         //* * Sample output | ||||||
|  |         for (int i = 0; i < apples.length; i++) | ||||||
|  |             System.out.println(apples[i]); | ||||||
|  | 
 | ||||||
|  |         oranges[0] = new Orange(4); | ||||||
|  |         oranges[1] = new Orange(1); | ||||||
|  |         // * Should give runtime exception as ClassCastException is a runtime exception | ||||||
|  |         //selection.sort(oranges); | ||||||
|  |         Selection<Orange> selection2 = new Selection<Orange>(); | ||||||
|  |         // * Should result in a compile time exception, as casting to Orange will fail | ||||||
|  |         //selection2.sort(apples); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private static class Orange{ | ||||||
|  |         private int size; | ||||||
|  |         Orange(int size){ | ||||||
|  |             this.size = size; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public String toString() { | ||||||
|  |             return "An orange of size "+size; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private static class Apple implements Comparable<Apple>{ | ||||||
|  |         private int size; | ||||||
|  | 
 | ||||||
|  |         Apple(int size){ | ||||||
|  |             this.size = size; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public String toString() { | ||||||
|  |             return "An apple of size "+size; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public int compareTo(Apple that) { | ||||||
|  |             if (this.size < that.size) return -1; | ||||||
|  |             else if (this.size == that.size)return 0; | ||||||
|  |             else return 1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,29 @@ | |||||||
|  | package com.hithomelabs.clients.module5; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module5.Shell; | ||||||
|  | 
 | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class ShellClient { | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args) { | ||||||
|  | 
 | ||||||
|  |         int size = 100; | ||||||
|  |         Apple[] apples = new Apple[size]; | ||||||
|  |         Shell<Apple> shell = new Shell<Apple>(); | ||||||
|  | 
 | ||||||
|  |         for (int i = 0; i < apples.length; i++) { | ||||||
|  |             apples[i] = new Apple(new Random().nextInt(1000)); | ||||||
|  |         } | ||||||
|  |         Apple[] applesCopy = Arrays.copyOf(apples, size); | ||||||
|  |         shell.sort(apples); | ||||||
|  |         shell.insertionSort(applesCopy); | ||||||
|  | 
 | ||||||
|  |         //* * Sample output | ||||||
|  |         for (int i = 0; i < apples.length; i++) | ||||||
|  |             System.out.println(apples[i]); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| @ -0,0 +1,23 @@ | |||||||
|  | package com.hithomelabs.clients.module6; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module6.Merge; | ||||||
|  | 
 | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class MergeClient { | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args) { | ||||||
|  |         int size = 100; | ||||||
|  |         Apple[] apples = new Apple[size]; | ||||||
|  |         Merge<Apple> merge = new Merge<Apple>(); | ||||||
|  | 
 | ||||||
|  |         for (int i = 0; i < apples.length; i++) { | ||||||
|  |             apples[i] = new Apple(new Random().nextInt(1000)); | ||||||
|  |         } | ||||||
|  |         merge.sort(apples); | ||||||
|  |         for (int i = 0; i < apples.length; i++) | ||||||
|  |             System.out.println(apples[i]); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,22 @@ | |||||||
|  | package com.hithomelabs.clients.module7; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module7.Quick; | ||||||
|  | 
 | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class QuickSortClient { | ||||||
|  | 
 | ||||||
|  |     public static void main(String[] args) { | ||||||
|  |         int size = 100; | ||||||
|  |         Apple[] apples = new Apple[size]; | ||||||
|  |         Quick<Apple> quick = new Quick<Apple>(); | ||||||
|  | 
 | ||||||
|  |         for (int i = 0; i < apples.length; i++) { | ||||||
|  |             apples[i] = new Apple(new Random().nextInt(1000)); | ||||||
|  |         } | ||||||
|  |         quick.sort(apples); | ||||||
|  |         for (int i = 0; i < apples.length; i++) | ||||||
|  |             System.out.println(apples[i]); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -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,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]); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,18 @@ | |||||||
|  | package com.hithomelabs.clients.module8; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import com.hithomelabs.princeton1.module8.PriorityQueue; | ||||||
|  | 
 | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | public class PriorityQueueClient { | ||||||
|  |     public static void main(String[] args){ | ||||||
|  |         PriorityQueue<Apple> priorityQueue = new PriorityQueue<>(); | ||||||
|  |         for(int i=0; i<100; i++){ | ||||||
|  |             priorityQueue.enqueue(new Apple(new Random().nextInt(100))); | ||||||
|  |         } | ||||||
|  |         while (!priorityQueue.isEmpty()){ | ||||||
|  |             System.out.println(priorityQueue.dequeue()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								common/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								common/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,24 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | group = 'com.hithomelabs.princeton1.common' | ||||||
|  | version = 'unspecified' | ||||||
|  | 
 | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | dependencies { | ||||||
|  |     testImplementation platform('org.junit:junit-bom:5.10.0') | ||||||
|  |     testImplementation 'org.junit.jupiter:junit-jupiter' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(11) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | test { | ||||||
|  |     useJUnitPlatform() | ||||||
|  | } | ||||||
| @ -0,0 +1,46 @@ | |||||||
|  | package com.hithomelabs.princeton1.common; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | import java.util.Objects; | ||||||
|  | 
 | ||||||
|  | public class Apple implements Comparable<Apple> { | ||||||
|  |     private int size; | ||||||
|  |     public static Comparator<Apple> COMPARE_BY_SIZE = new Comparator<Apple>() { | ||||||
|  |         @Override | ||||||
|  |         public int compare(Apple a1, Apple a2) { | ||||||
|  |             if(a1.size < a2.size) return -1; | ||||||
|  |             else if (a1.size == (a2.size)) return 0; | ||||||
|  |             else return 1; | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     public Apple(int size) { | ||||||
|  |         this.size = size; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean equals(Object obj) { | ||||||
|  |         if(this == obj) return true; | ||||||
|  |         if (obj == null || this.getClass() != obj.getClass()) | ||||||
|  |             return false; | ||||||
|  |         Apple that = (Apple) obj; | ||||||
|  |         return Objects.equals(this.size, that.size); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public int hashCode() { | ||||||
|  |         return Objects.hash(size); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "An apple of size " + size; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public int compareTo(Apple that) { | ||||||
|  |         if (this.size < that.size) return -1; | ||||||
|  |         else if (this.size == that.size) return 0; | ||||||
|  |         else return 1; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,14 @@ | |||||||
|  | package com.hithomelabs.princeton1.common; | ||||||
|  | 
 | ||||||
|  | public class Orange { | ||||||
|  |     private int size; | ||||||
|  | 
 | ||||||
|  |     public Orange(int size) { | ||||||
|  |         this.size = size; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "An orange of size " + size; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,8 +1,9 @@ | |||||||
| package com.hithomelabs.princeton1.module4; | package com.hithomelabs.princeton1.module4; | ||||||
| 
 | 
 | ||||||
| import javax.annotation.Nonnull; |  | ||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| 
 | 
 | ||||||
|  | import javax.annotation.Nonnull; | ||||||
|  | 
 | ||||||
| public class ArrayQueue<E> extends Queue<E>{ | public class ArrayQueue<E> extends Queue<E>{ | ||||||
| 
 | 
 | ||||||
|     // insertion from tail, removal from head |     // insertion from tail, removal from head | ||||||
|  | |||||||
| @ -1,13 +1,13 @@ | |||||||
| package com.hithomelabs.princeton1.module4; | package com.hithomelabs.princeton1.module4; | ||||||
| import javax.annotation.Nonnull; |  | ||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
|  | 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 |     // Capacity and size are two variables, capacity determines total capacity of array, capacity defaults at 10 | ||||||
|     // Everytime size == capacity, capacity = 2 * capacity |     // every time size == capacity, capacity = 2 * capacity | ||||||
|     private static final int DEFAULT_CAPACITY = 10; |     private static final int DEFAULT_CAPACITY = 10; | ||||||
|     private int capacity; |     private int capacity; | ||||||
|     private int size; |     private int size; | ||||||
| @ -18,7 +18,7 @@ public class ArrayStack<E> extends Stack<E> { | |||||||
|         arr = (E[]) new Object[this.capacity]; |         arr = (E[]) new Object[this.capacity]; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Constructor chaining, default constructor will call parametrised constructor with default initial capacity 10 |     // Constructor chaining, default constructor will call parametrized constructor with default initial capacity 10 | ||||||
|     public ArrayStack(){ |     public ArrayStack(){ | ||||||
|         this(DEFAULT_CAPACITY); |         this(DEFAULT_CAPACITY); | ||||||
|     } |     } | ||||||
| @ -64,7 +64,7 @@ public class ArrayStack<E> extends Stack<E> { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void checkResize() { |     private void checkResize() { | ||||||
|         if (size < capacity / 4 && capacity >= 40){ |         if (size < capacity / 4 && capacity >= 20){ | ||||||
|             capacity = capacity / 2; |             capacity = capacity / 2; | ||||||
|             changeCapacity(capacity); |             changeCapacity(capacity); | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -60,7 +60,7 @@ public class LinkedQueue<E> extends Queue<E>{ | |||||||
|             Node current = head; |             Node current = head; | ||||||
|             @Override |             @Override | ||||||
|             public boolean hasNext() { |             public boolean hasNext() { | ||||||
|                 return current != tail; |                 return current != null; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             @Override |             @Override | ||||||
|  | |||||||
| @ -0,0 +1,76 @@ | |||||||
|  | package com.hithomelabs.princeton1.module4; | ||||||
|  | 
 | ||||||
|  | import java.util.Iterator; | ||||||
|  | import org.junit.jupiter.api.AfterEach; | ||||||
|  | import org.junit.jupiter.api.BeforeEach; | ||||||
|  | import org.junit.jupiter.api.DisplayName; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  | 
 | ||||||
|  | class ArrayQueueTest { | ||||||
|  | 
 | ||||||
|  |     private Queue<Integer> queue; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         queue = new ArrayQueue<Integer>(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         queue = null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Empty queue must return size zero") | ||||||
|  |     public void testEmptyQueueSize(){ | ||||||
|  |         assertEquals(0, queue.size()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Enqueuing must work as expected") | ||||||
|  |     public void testEnqueue(){ | ||||||
|  |         queue.enqueue(1); | ||||||
|  |         queue.enqueue(2); | ||||||
|  |         assertEquals(2,queue.size()); | ||||||
|  |         Iterator<Integer> iterator = queue.iterator(); | ||||||
|  |         assertEquals(1, iterator.next()); | ||||||
|  |         assertEquals(2, iterator.next()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Dequeueing must work as expected") | ||||||
|  |     public void testDequeue(){ | ||||||
|  |         queue.enqueue(1); | ||||||
|  |         queue.enqueue(2); | ||||||
|  |         assertEquals(1, queue.dequeue()); | ||||||
|  |         queue.enqueue(3); | ||||||
|  |         assertEquals(2, queue.size()); | ||||||
|  |         assertEquals(2, queue.dequeue()); | ||||||
|  |         assertEquals(3, queue.dequeue()); | ||||||
|  |         assertEquals(0, queue.size()); | ||||||
|  |         assertNull(queue.dequeue()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Testing resizable array and iterator") | ||||||
|  |     public void testResize(){ | ||||||
|  |         for(int i = 0; i < 21; i++) | ||||||
|  |             queue.enqueue(i); | ||||||
|  |         for(int i = 0; i < 13; i++){ | ||||||
|  |             queue.dequeue(); | ||||||
|  |         } | ||||||
|  |         assertEquals(13, queue.dequeue()); | ||||||
|  |         assertEquals(7,queue.size()); | ||||||
|  |         Integer[] arr = new Integer[queue.size()]; | ||||||
|  |         Iterator<Integer> iterator = queue.iterator(); | ||||||
|  |         int count = 0; | ||||||
|  |         while(iterator.hasNext()){ | ||||||
|  |             arr[count++] = iterator.next(); | ||||||
|  |         } | ||||||
|  |         assertArrayEquals(new Integer[]{14, 15, 16, 17, 18, 19, 20}, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,85 @@ | |||||||
|  | package com.hithomelabs.princeton1.module4; | ||||||
|  | 
 | ||||||
|  | import org.junit.jupiter.api.AfterEach; | ||||||
|  | import org.junit.jupiter.api.BeforeEach; | ||||||
|  | import org.junit.jupiter.api.DisplayName; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | 
 | ||||||
|  | import java.util.Iterator; | ||||||
|  | 
 | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  | 
 | ||||||
|  | class ArrayStackTest { | ||||||
|  | 
 | ||||||
|  |     private Stack<String> stack; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         stack = new ArrayStack<String>(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         stack = null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Empty stack must return size zero") | ||||||
|  |     public void testEmptyStackSize(){ | ||||||
|  |         assertEquals(0, stack.size()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Push must work as expected") | ||||||
|  |     public void testEnqueue(){ | ||||||
|  |         stack.push("Hello"); | ||||||
|  |         stack.push("World"); | ||||||
|  |         assertEquals(2,stack.size()); | ||||||
|  |         Iterator<String> iterator = stack.iterator(); | ||||||
|  |         assertEquals("Hello", iterator.next()); | ||||||
|  |         assertEquals("World", iterator.next()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Pop must work as expected") | ||||||
|  |     public void testDequeue(){ | ||||||
|  |         stack.push("hello"); | ||||||
|  |         stack.push("world"); | ||||||
|  |         assertEquals("world", stack.pop()); | ||||||
|  |         stack.push("I"); | ||||||
|  |         assertEquals(2, stack.size()); | ||||||
|  |         assertEquals("I", stack.pop()); | ||||||
|  |         assertEquals("hello", stack.pop()); | ||||||
|  |         assertEquals(0, stack.size()); | ||||||
|  |         assertNull(stack.pop()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Testing resizable array and iterator") | ||||||
|  |     public void testResize(){ | ||||||
|  |         stack.push("Hello"); | ||||||
|  |         stack.push("world"); | ||||||
|  |         stack.push("I"); | ||||||
|  |         stack.push("am"); | ||||||
|  |         stack.push("testing"); | ||||||
|  |         stack.push("my"); | ||||||
|  |         stack.push("implementation"); | ||||||
|  |         stack.push("of"); | ||||||
|  |         stack.push("Stacks"); | ||||||
|  |         stack.push("Data"); | ||||||
|  |         stack.push("Structure"); | ||||||
|  |         assertEquals("Structure", stack.pop()); | ||||||
|  |         int counter = 6; | ||||||
|  |         while(counter-- > 0) | ||||||
|  |             stack.pop(); | ||||||
|  |         assertEquals(4,stack.size()); | ||||||
|  |         String[] arr = new String[stack.size()]; | ||||||
|  |         Iterator<String> iterator = stack.iterator(); | ||||||
|  |         int count = 0; | ||||||
|  |         while(iterator.hasNext()){ | ||||||
|  |             arr[count++] = iterator.next(); | ||||||
|  |         } | ||||||
|  |         assertArrayEquals(new String[]{"Hello", "world", "I", "am"}, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,76 @@ | |||||||
|  | package com.hithomelabs.princeton1.module4; | ||||||
|  | 
 | ||||||
|  | import org.junit.jupiter.api.AfterEach; | ||||||
|  | import org.junit.jupiter.api.BeforeEach; | ||||||
|  | import org.junit.jupiter.api.DisplayName; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | 
 | ||||||
|  | import java.util.Iterator; | ||||||
|  | 
 | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  | 
 | ||||||
|  | class LinkedQueueTest { | ||||||
|  | 
 | ||||||
|  |     private Queue<Integer> queue; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         queue = new LinkedQueue<>(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         queue = null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Empty queue must return size zero") | ||||||
|  |     public void testEmptyQueueSize(){ | ||||||
|  |         assertEquals(0, queue.size()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Enqueuing must work as expected") | ||||||
|  |     public void testEnqueue(){ | ||||||
|  |         queue.enqueue(1); | ||||||
|  |         queue.enqueue(2); | ||||||
|  |         assertEquals(2,queue.size()); | ||||||
|  |         Iterator<Integer> iterator = queue.iterator(); | ||||||
|  |         assertEquals(1, iterator.next()); | ||||||
|  |         assertEquals(2, iterator.next()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Dequeueing must work as expected") | ||||||
|  |     public void testDequeue(){ | ||||||
|  |         queue.enqueue(1); | ||||||
|  |         queue.enqueue(2); | ||||||
|  |         assertEquals(1, queue.dequeue()); | ||||||
|  |         queue.enqueue(3); | ||||||
|  |         assertEquals(2, queue.size()); | ||||||
|  |         assertEquals(2, queue.dequeue()); | ||||||
|  |         assertEquals(3, queue.dequeue()); | ||||||
|  |         assertEquals(0, queue.size()); | ||||||
|  |         assertNull(queue.dequeue()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Testing resizable array and iterator") | ||||||
|  |     public void testResize(){ | ||||||
|  |         for(int i = 0; i < 21; i++) | ||||||
|  |             queue.enqueue(i); | ||||||
|  |         for(int i = 0; i < 13; i++){ | ||||||
|  |             queue.dequeue(); | ||||||
|  |         } | ||||||
|  |         assertEquals(13, queue.dequeue()); | ||||||
|  |         assertEquals(7,queue.size()); | ||||||
|  |         Integer[] arr = new Integer[queue.size()]; | ||||||
|  |         Iterator<Integer> iterator = queue.iterator(); | ||||||
|  |         int count = 0; | ||||||
|  |         while(iterator.hasNext()){ | ||||||
|  |             arr[count++] = iterator.next(); | ||||||
|  |         } | ||||||
|  |         assertArrayEquals(new Integer[]{14, 15, 16, 17, 18, 19, 20}, arr); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								module5/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								module5/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,24 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | group = 'com.hithomelabs.princeton1.module5' | ||||||
|  | version = 'unspecified' | ||||||
|  | 
 | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | dependencies { | ||||||
|  |     testImplementation platform('org.junit:junit-bom:5.10.0') | ||||||
|  |     testImplementation 'org.junit.jupiter:junit-jupiter' | ||||||
|  |     testImplementation project(':common') | ||||||
|  | } | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(11) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | test { | ||||||
|  |     useJUnitPlatform() | ||||||
|  | } | ||||||
| @ -0,0 +1,18 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | // * * Provides a set of helper functions less and exch for Comparable data types | ||||||
|  | public interface ComparableHelper { | ||||||
|  | 
 | ||||||
|  |     static <T> void exch(T[] arr, int j, int i) { | ||||||
|  |         T temp = arr[i]; | ||||||
|  |         arr[i] = arr[j]; | ||||||
|  |         arr[j] = temp; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static <T> boolean less(T e1, T e2) { | ||||||
|  |         return ((Comparable<T>)e1).compareTo(e2) < 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static <T> boolean equals(T e1, T e2) { return ((Comparable<T>)e1).compareTo(e2) == 0;} | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,7 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | public interface ComparableSort<E> { | ||||||
|  | 
 | ||||||
|  |     void sort(E[] arr); | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,19 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public interface ComparatorHelper extends ComparableHelper { | ||||||
|  | 
 | ||||||
|  |     static <T> boolean less(T v, T w, Comparator<T> cmp) { | ||||||
|  |         if (cmp == null) return ComparableHelper.less(v, w); | ||||||
|  |         else | ||||||
|  |             return cmp.compare(v, w) < 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static <T> boolean equals(T v, T w, Comparator<T> cmp) { | ||||||
|  |         if (cmp == null) return ComparableHelper.equals(v, w); | ||||||
|  |         else | ||||||
|  |             return cmp.compare(v, w) == 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,9 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public interface ComparatorSort<E> extends ComparableSort<E> { | ||||||
|  | 
 | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp); | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,46 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public class Insertion<E> implements MeasurableSort<E>, MeasurableHelper{ | ||||||
|  | 
 | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         coreSortLogic(arr, null, null); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void coreSortLogic(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if (arr == null) return; | ||||||
|  |         else { | ||||||
|  |             int N = arr.length; | ||||||
|  |             // * * swap arr[i] with each element greater to it's left | ||||||
|  |             for (int i = 1; i < N; i++) { | ||||||
|  |                 int j = i; | ||||||
|  |                 while (j >= 1 && MeasurableHelper.less(arr[j], arr[j - 1], cmp, metaData)) { | ||||||
|  |                     MeasurableHelper.exch(arr, j, j - 1, metaData); | ||||||
|  |                     j = j - 1; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if (metaData !=  null) | ||||||
|  |             metaData.startTime(); | ||||||
|  |         coreSortLogic(arr, cmp, metaData); | ||||||
|  |         if (metaData !=  null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         coreSortLogic(arr, cmp, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Insertion Sort"; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| @ -0,0 +1,25 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public interface MeasurableHelper extends ComparatorHelper{ | ||||||
|  | 
 | ||||||
|  |     static <T> boolean less(T v, T w, Comparator<T> cmp, SortingMetaData metaData) { | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.incrementCompares(); | ||||||
|  |         return ComparatorHelper.less(v, w, cmp); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static <T> boolean equals(T v, T w, Comparator<T> cmp, SortingMetaData metaData) { | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.incrementCompares(); | ||||||
|  |         return ComparatorHelper.equals(v, w, cmp); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static <T> void exch(T[] arr, int j, int i, SortingMetaData metaData) { | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.incrementExchanges(); | ||||||
|  |         ComparableHelper.exch(arr, j, i); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,9 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public interface MeasurableSort<E> extends ComparatorSort<E> { | ||||||
|  | 
 | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData); | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,47 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public class Selection<E> implements MeasurableSort<E>, MeasurableHelper { | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     * * 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] | ||||||
|  |     */ | ||||||
|  |     public void sort(E[] arr){ | ||||||
|  |         coreSortLogic(arr, null, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void coreSortLogic(E[] arr, Comparator<E> cmp, SortingMetaData metaData){ | ||||||
|  |         if (arr ==  null) return; | ||||||
|  |         Comparable<E>[] arr1 = (Comparable<E>[]) arr; | ||||||
|  |         for(int i = 0; i < arr1.length - 1; i++){ | ||||||
|  |             int minIndex = i; | ||||||
|  |             for(int j = i+1; j < arr.length; j ++){ | ||||||
|  |                 if (MeasurableHelper.less(arr[j], arr[minIndex], cmp, metaData)) minIndex = j; | ||||||
|  |             } | ||||||
|  |             MeasurableHelper.exch(arr, i, minIndex, metaData); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.startTime(); | ||||||
|  |         coreSortLogic(arr, cmp, metaData); | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         coreSortLogic(arr, cmp, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Selection Sort"; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| @ -0,0 +1,77 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public class Shell<E> implements MeasurableSort<E>, MeasurableHelper { | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  |  * * We will be performing h sort | ||||||
|  |  * * Suppose or function to determine subsequent values of h is: | ||||||
|  |  * * h(i+1) = 3*h(i) + 1; h = 1, 4, 13, 40, 121, .... | ||||||
|  |  * * h will never be perfectly divisible by 3; further dividing h[i]/3 will give h[i-1] | ||||||
|  |  * * We want to h-sort using larges value of h smaller than N, followed by smaller values of h | ||||||
|  |  * * If N = 100, we h-sort by 40, meaning every 40th element will be in order | ||||||
|  |  * * Then we h-sort by 13, meaning every 40th and every 13th element will be in order and every 40th element will be in order | ||||||
|  |  * * Finally, when h will come out as 1, it will be same as insertion sort, however by that time the array will almost be sorted | ||||||
|  |  * * Insertion sort for an almost sorted array is linear time. | ||||||
|  |  * * As a case study we implement both insertion sort and selection sort for an array of 1000 nos. | ||||||
|  |  * * And check number of compares and no. of exchanges in each case | ||||||
|  |  */ | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         coreSortLogic(arr,null,null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void coreSortLogic(E[] arr, Comparator<E> cmp, SortingMetaData metaData){ | ||||||
|  |         int N = arr.length; | ||||||
|  |         int h = 1; | ||||||
|  |         // * * Calculates the largest value of h greater than n | ||||||
|  |         while (3 * h + 1 < N) { | ||||||
|  |             h = 3 * h + 1; | ||||||
|  |         } | ||||||
|  |         while (h >= 1) { | ||||||
|  |             h = hsort(arr, h, cmp, metaData); | ||||||
|  |             h = h / 3; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private int hsort(E[] arr, int h, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         int N  = arr.length; | ||||||
|  |         for(int i = h; i < N; i++){ | ||||||
|  |             int j = i; | ||||||
|  |             while(j >= h && MeasurableHelper.less(arr[j], arr[j-h], cmp, metaData)){ | ||||||
|  |                 MeasurableHelper.exch(arr, j, j-h, metaData); | ||||||
|  |                 j = j - h; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return h; | ||||||
|  |     } | ||||||
|  |     /* | ||||||
|  |      * Sample implementation of insertion sort as h-sort of h = 1 | ||||||
|  |      * Will just be comparing the number of saps taken across both implementations | ||||||
|  |     */ | ||||||
|  |     public void insertionSort(E[] arr){ | ||||||
|  |         int h = 1; | ||||||
|  |         h = hsort(arr, h, null, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.startTime(); | ||||||
|  |         coreSortLogic(arr, cmp, metaData); | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         coreSortLogic(arr, cmp, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Shell Sort"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,41 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | public class SortingMetaData { | ||||||
|  | 
 | ||||||
|  |     private double tick; | ||||||
|  |     private double tok; | ||||||
|  |     private double exchanges; | ||||||
|  |     private double compares; | ||||||
|  | 
 | ||||||
|  |     public double timeElapsed(){ | ||||||
|  |         return tok - tick; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void startTime(){ | ||||||
|  |         tick = System.nanoTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void endTime(){ | ||||||
|  |         tok = System.nanoTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void incrementCompares(){ | ||||||
|  |         ++compares; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void incrementExchanges(){ | ||||||
|  |         ++exchanges; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public double getExchanges(){ | ||||||
|  |         return exchanges; | ||||||
|  |     } | ||||||
|  |     public double getCompares(){ | ||||||
|  |         return compares; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Time elapsed: " + this.timeElapsed() + " nano-seconds \nCompares: "+this.compares+ "\nSwaps: "+this.exchanges; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,56 @@ | |||||||
|  | package com.hithomelabs.princeton1.module5; | ||||||
|  | 
 | ||||||
|  | import org.junit.jupiter.api.AfterEach; | ||||||
|  | import org.junit.jupiter.api.BeforeEach; | ||||||
|  | import org.junit.jupiter.api.DisplayName; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | class SortTest { | ||||||
|  | 
 | ||||||
|  |     private ArrayList<Apple> apples; | ||||||
|  |     private ComparableSort<Apple> sortingAlgorithm; | ||||||
|  |     private Random random; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         apples = new ArrayList<Apple>(); | ||||||
|  |         //sortingAlgorithm = new Selection<Apple>(); | ||||||
|  |         random = new Random(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void testSort(ComparableSort<Apple> sortingAlgorithm) { | ||||||
|  |         for (int i = 0; i < 100; i++) | ||||||
|  |             apples.add(new Apple(random.nextInt(100))); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Testing Insertion sort functionality") | ||||||
|  |     public void testInsertionSort() { | ||||||
|  |         sortingAlgorithm = new Insertion<Apple>(); | ||||||
|  |         testSort(sortingAlgorithm); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Testing Selection sort functionality") | ||||||
|  |     public void testSelectionSort() { | ||||||
|  |         sortingAlgorithm = new Selection<Apple>(); | ||||||
|  |         testSort(sortingAlgorithm); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Testing Shell sort functionality") | ||||||
|  |     public void testShellSort() { | ||||||
|  |         sortingAlgorithm = new Shell<>(); | ||||||
|  |         testSort(sortingAlgorithm); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         sortingAlgorithm = null; | ||||||
|  |         apples = null; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										25
									
								
								module6/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								module6/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | group = 'com.hithomelabs.princeton1.module6' | ||||||
|  | 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') | ||||||
|  | } | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(11) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | test { | ||||||
|  |     useJUnitPlatform() | ||||||
|  | } | ||||||
| @ -0,0 +1,79 @@ | |||||||
|  | package com.hithomelabs.princeton1.module6; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.ComparableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableHelper; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.SortingMetaData; | ||||||
|  | 
 | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public class Merge<E> implements MeasurableSort<E>, MeasurableHelper { | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         coreSortLogic(arr, null, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void coreSortLogic(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         // * * aux is a helper array required for merge | ||||||
|  |         E[] aux = Arrays.copyOf(arr, N); | ||||||
|  |         mergesort(arr, aux, 0, N - 1, cmp, metaData); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void mergesort(E[] arr, E[] aux, int lo, int hi, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  | 
 | ||||||
|  |         if (hi <= lo) return; | ||||||
|  |         int mid = lo + (hi - lo) / 2; | ||||||
|  |         mergesort(arr, aux, lo, mid, cmp, metaData); | ||||||
|  |         mergesort(arr, aux, mid + 1, hi, cmp, metaData); | ||||||
|  |         merge(arr, aux, lo, mid, hi, cmp, metaData); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void merge(E[] arr, E[] aux, int lo, int mid, int hi, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  | 
 | ||||||
|  |         // * * creating backup of original array | ||||||
|  |         for (int i = lo; i <= hi; i++) | ||||||
|  |             aux[i] = arr[i]; | ||||||
|  | 
 | ||||||
|  |         int i = lo; | ||||||
|  |         int j = mid + 1; | ||||||
|  |         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 (metaData != null) | ||||||
|  |                     metaData.incrementCompares(); | ||||||
|  |             } else if (j > hi) { | ||||||
|  |                 arr[k] = aux[i++]; | ||||||
|  |                 if (metaData != null) | ||||||
|  |                     metaData.incrementCompares(); | ||||||
|  |             } else if (MeasurableHelper.less( aux[i], aux[j], cmp, metaData)) { | ||||||
|  |                 arr[k] = aux[i++]; | ||||||
|  |             } | ||||||
|  |             else arr[k] = aux[j++]; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.startTime(); | ||||||
|  |         coreSortLogic(arr, cmp, metaData); | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         coreSortLogic(arr, cmp, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Merge Sort"; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,44 @@ | |||||||
|  | package com.hithomelabs.princeton1.module6; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.ComparableSort; | ||||||
|  | import com.hithomelabs.princeton1.common.Apple; | ||||||
|  | import org.junit.jupiter.api.AfterEach; | ||||||
|  | import org.junit.jupiter.api.BeforeEach; | ||||||
|  | import org.junit.jupiter.api.DisplayName; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | 
 | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  | 
 | ||||||
|  | class MergeTest { | ||||||
|  | 
 | ||||||
|  |     private ComparableSort<Apple> sortingAlgorithm; | ||||||
|  |     private ArrayList<Apple> apples; | ||||||
|  |     private Random random; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         apples = new ArrayList<>(); | ||||||
|  |         random = new Random(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("Merge Sort test client") | ||||||
|  |     public void testSort(){ | ||||||
|  |         sortingAlgorithm = new Merge<Apple>(); | ||||||
|  |         for(int i = 0; i < 10; i++) | ||||||
|  |             apples.add(new Apple(random.nextInt(100))); | ||||||
|  |         Apple[] arr = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         apples.sort(null); | ||||||
|  |         Apple[] sorted = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         sortingAlgorithm.sort(arr); | ||||||
|  |         assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         sortingAlgorithm = null; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								module7/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								module7/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | group = 'com.hithomelabs.princeton1.module7' | ||||||
|  | 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,79 @@ | |||||||
|  | package com.hithomelabs.princeton1.module7; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableHelper; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.SortingMetaData; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public class Quick<E> implements MeasurableSort<E>, MeasurableHelper { | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         quickSort(arr, 0, N - 1, null, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void altSort(E[] arr) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         altQuickSort(arr, 0, N-1); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void altQuickSort(E[] arr, int lo, int hi) { | ||||||
|  |         if (lo >= hi) return; | ||||||
|  |         int i = lo + 1; | ||||||
|  |         int j = i; | ||||||
|  |         while(j <= hi){ | ||||||
|  |             if(MeasurableHelper.less((Comparable<E>) arr[j], arr[lo], null, null)){ | ||||||
|  |                 MeasurableHelper.exch(arr, i, j, null); | ||||||
|  |                 i++; | ||||||
|  |             } | ||||||
|  |             j++; | ||||||
|  |         } | ||||||
|  |         MeasurableHelper.exch(arr, i-1, lo,null); | ||||||
|  |         altQuickSort(arr, lo, i-2); | ||||||
|  |         altQuickSort(arr, i, hi); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void quickSort(E[] arr, int lo, int hi, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  | 
 | ||||||
|  |         if (lo >= hi) return; | ||||||
|  |         int i = lo; | ||||||
|  |         int j = hi+1; | ||||||
|  |         while(true){ | ||||||
|  |             while(MeasurableHelper.less( arr[++i], arr[lo], cmp, metaData)){ | ||||||
|  |                 if(i == hi) break; | ||||||
|  |             } | ||||||
|  |             while(!MeasurableHelper.less(arr[--j], arr[lo], cmp, metaData)){ | ||||||
|  |                 if (j == lo ) break; | ||||||
|  |             } | ||||||
|  |             if(j<=i) break; | ||||||
|  |             MeasurableHelper.exch(arr, i , j, metaData); | ||||||
|  |         } | ||||||
|  |         MeasurableHelper.exch(arr, j, lo, metaData); | ||||||
|  |         quickSort(arr, lo, j-1, cmp, metaData); | ||||||
|  |         quickSort(arr, j+1, hi, cmp, metaData); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         quickSort(arr, 0, N - 1, cmp, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if(metaData != null){ | ||||||
|  |             metaData.startTime(); | ||||||
|  |         } | ||||||
|  |         int N = arr.length; | ||||||
|  |         quickSort(arr, 0, N - 1, cmp, metaData); | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public String toString() { | ||||||
|  |             return "Quick Sort"; | ||||||
|  |         } | ||||||
|  | } | ||||||
| @ -0,0 +1,58 @@ | |||||||
|  | package com.hithomelabs.princeton1.module7; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableHelper; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.SortingMetaData; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public class ThreeWayQuick<E> implements MeasurableSort<E>, MeasurableHelper { | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         coreSortingLogic(arr, null, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void coreSortingLogic(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         threeWaySort(arr, 0, N - 1, cmp, metaData); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void threeWaySort(E[] arr, int lo, int hi, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  | 
 | ||||||
|  |         if (hi <= lo) | ||||||
|  |             return; | ||||||
|  |         int k = hi; | ||||||
|  |         int i = lo + 1; | ||||||
|  |         int j = lo; | ||||||
|  | 
 | ||||||
|  |         while (true) { | ||||||
|  |             if (MeasurableHelper.less(arr[i], arr[j], cmp, metaData)) MeasurableHelper.exch(arr, i++, j++, metaData); | ||||||
|  |             else if (MeasurableHelper.equals(arr[i],arr[j], cmp, metaData)) i++; | ||||||
|  |             else MeasurableHelper.exch(arr, i, k--, metaData); | ||||||
|  |             if (k < i) break; | ||||||
|  |         } | ||||||
|  |         threeWaySort(arr, lo, j - 1, cmp, metaData); | ||||||
|  |         threeWaySort(arr, k + 1, hi, cmp, metaData); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         if(metaData != null){ | ||||||
|  |             metaData.startTime(); | ||||||
|  |         } | ||||||
|  |         coreSortingLogic(arr, cmp, metaData); | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         coreSortingLogic(arr, cmp, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Three Way Quick Sort"; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,68 @@ | |||||||
|  | package com.hithomelabs.princeton1.module7; | ||||||
|  | 
 | ||||||
|  | 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 QuickTest { | ||||||
|  | 
 | ||||||
|  |     private Quick<Apple> quick; | ||||||
|  |     private ArrayList<Apple> apples; | ||||||
|  |     private Random random; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         quick = new Quick<Apple>(); | ||||||
|  |         apples = new ArrayList<Apple>(); | ||||||
|  |         random = new Random(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("testing Quick sort default implementation") | ||||||
|  |     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()]); | ||||||
|  |         quick.sort(arr); | ||||||
|  |         apples.sort(null); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("testing Quick sort alternate implementation") | ||||||
|  |     public void testAltSort(){ | ||||||
|  | 
 | ||||||
|  |         for(int i = 0; i < 100; i++) | ||||||
|  |             apples.add(new Apple(random.nextInt(1000))); | ||||||
|  |         Apple[] arr = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         quick.altSort(arr); | ||||||
|  |         apples.sort(null); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("testing Comparator sort") | ||||||
|  |     public void testComparatorSort(){ | ||||||
|  |         for(int i = 0; i < 100; i++) | ||||||
|  |             apples.add(new Apple(random.nextInt(1000))); | ||||||
|  |         Apple[] arr = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         quick.sort(arr, Apple.COMPARE_BY_SIZE); | ||||||
|  |         apples.sort(Apple.COMPARE_BY_SIZE); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         quick = null; | ||||||
|  |         apples = null; | ||||||
|  |         random = null; | ||||||
|  |         } | ||||||
|  | } | ||||||
| @ -0,0 +1,54 @@ | |||||||
|  | package com.hithomelabs.princeton1.module7; | ||||||
|  | 
 | ||||||
|  | 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 ThreeWayQuickTest { | ||||||
|  | 
 | ||||||
|  |     private ThreeWayQuick<Apple> quick; | ||||||
|  |     private ArrayList<Apple> apples; | ||||||
|  |     private Random random; | ||||||
|  | 
 | ||||||
|  |     @BeforeEach | ||||||
|  |     void setUp() { | ||||||
|  |         quick = new ThreeWayQuick<Apple>(); | ||||||
|  |         apples = new ArrayList<Apple>(); | ||||||
|  |         random = new Random(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("testing Quick sort default implementation") | ||||||
|  |     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()]); | ||||||
|  |         quick.sort(arr); | ||||||
|  |         apples.sort(null); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     @DisplayName("testing Comparator sort") | ||||||
|  |     public void testComparatorSort(){ | ||||||
|  |         for(int i = 0; i < 100; i++) | ||||||
|  |             apples.add(new Apple(random.nextInt(1000))); | ||||||
|  |         Apple[] arr = apples.toArray(new Apple[apples.size()]); | ||||||
|  |         quick.sort(arr, Apple.COMPARE_BY_SIZE); | ||||||
|  |         apples.sort(Apple.COMPARE_BY_SIZE); | ||||||
|  |         Apple[] sorted =  apples.toArray(new Apple[apples.size()]); | ||||||
|  |         Assertions.assertArrayEquals(sorted, arr); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @AfterEach | ||||||
|  |     void tearDown() { | ||||||
|  |         quick = null; | ||||||
|  |         apples = null; | ||||||
|  |         random = null; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								module8/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								module8/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | 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') | ||||||
|  |     implementation project(':module4') | ||||||
|  |     testImplementation project(':common') | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | test { | ||||||
|  |     useJUnitPlatform() | ||||||
|  | } | ||||||
| @ -0,0 +1,44 @@ | |||||||
|  | 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.MeasurableHelper; | ||||||
|  | import com.hithomelabs.princeton1.module5.SortingMetaData; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | public class Heap implements MeasurableHelper { | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     * * Sink Node T with to it's appropriate place in a Heap of size N, if it's children exist and are greater | ||||||
|  |     */ | ||||||
|  |     public static <T> void sink(T[] arr, int root, int N, Comparator<T> cmp, SortingMetaData metaData){ | ||||||
|  |         // *  Check if at least one child exists | ||||||
|  |         while(2 * root <= N){ | ||||||
|  |             int j = 2 * root; | ||||||
|  |         // *  Check if the right child exists and is larger than the left child, if yes swap right and left child | ||||||
|  |             if(j+1 <= N){ | ||||||
|  |                 if (MeasurableHelper.less(arr[j], arr[j+1], cmp, metaData)) j++; | ||||||
|  |             } | ||||||
|  |             if (!MeasurableHelper.less(arr[root], arr[j], cmp, metaData)) break; | ||||||
|  |             MeasurableHelper.exch(arr, root, j, metaData); | ||||||
|  |         // * The root node has now sunken low, call sink recursively with new node to check if it sinks further | ||||||
|  |             root = j; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // * * Swim if element is not root, and parent is lesser than node | ||||||
|  |     public static <T> void swim(T[] arr, int node, int N, Comparator<T> cmp, SortingMetaData metaData){ | ||||||
|  |         while(node > 1){ | ||||||
|  |             if(! MeasurableHelper.less(arr[node/2],arr[node], cmp, metaData)) break; | ||||||
|  |             MeasurableHelper.exch(arr, node, node/2, metaData); | ||||||
|  |             node = node/2; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,78 @@ | |||||||
|  | package com.hithomelabs.princeton1.module8; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableHelper; | ||||||
|  | import com.hithomelabs.princeton1.module5.MeasurableSort; | ||||||
|  | import com.hithomelabs.princeton1.module5.SortingMetaData; | ||||||
|  | 
 | ||||||
|  | import java.util.Comparator; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | public class HeapSort<E> implements MeasurableSort<E>, MeasurableHelper { | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         E[] heapArr = (E[]) new Object[N+1]; | ||||||
|  |         // * * to simplify we copy original array from | ||||||
|  |         System.arraycopy(arr, 0, heapArr, 1, N); | ||||||
|  |         // * * An array of size N holds a heap of size N-1 | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.startTime(); | ||||||
|  |         coreSortingLogic(heapArr, N, cmp, metaData); | ||||||
|  |         if (metaData != null) | ||||||
|  |             metaData.endTime(); | ||||||
|  |         System.arraycopy(heapArr, 1, arr, 0, N); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static <T> void heapify(T[] arr){ | ||||||
|  |         int N = arr.length; | ||||||
|  |         T[] heapArr = (T[]) new Object[N+1]; | ||||||
|  |         // * * to simplify we copy original array from | ||||||
|  |         System.arraycopy(arr, 0, heapArr, 1, N); | ||||||
|  |         // * * An array of size N holds a heap of size N-1 | ||||||
|  |         for (int i = N/2; i >= 1; i--) | ||||||
|  |             Heap.sink(heapArr, i, N, null, null); | ||||||
|  |         System.arraycopy(heapArr, 1, arr, 0, N); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void coreSortingLogic(E[] arr, int N, Comparator<E> cmp, SortingMetaData metaData) { | ||||||
|  |         // * * Converting array to max-heap an array in place | ||||||
|  |         for (int i = N/2; i >= 1; i--) | ||||||
|  |             Heap.sink(arr, i, N, cmp, metaData); | ||||||
|  |         // * * After converting to max-heap, in every iteration remove the max element of the heap | ||||||
|  |         while(N > 1){ | ||||||
|  |             MeasurableHelper.exch(arr, 1, N--, metaData); | ||||||
|  |             Heap.sink(arr, 1, N, cmp, metaData); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr, Comparator<E> cmp) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         E[] heapArr = (E[]) new Object[N+1]; | ||||||
|  |         // * * to simplify we copy original array from | ||||||
|  |         System.arraycopy(arr, 0, heapArr, 1, N); | ||||||
|  | 
 | ||||||
|  |         // * * An array of size N holds a heap of size N-1 | ||||||
|  |         coreSortingLogic(heapArr, N, cmp, null); | ||||||
|  |         System.arraycopy(heapArr, 1, arr, 0, N); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void sort(E[] arr) { | ||||||
|  |         int N = arr.length; | ||||||
|  |         E[] heapArr = (E[]) new Object[N+1]; | ||||||
|  |         // * * to simplify we copy original array from | ||||||
|  |         System.arraycopy(arr, 0, heapArr, 1, N); | ||||||
|  | 
 | ||||||
|  |         // * * An array of size N holds a heap of size N-1 | ||||||
|  |         coreSortingLogic(heapArr, N,null, null); | ||||||
|  |         System.arraycopy(heapArr, 1, arr, 0, N); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "Heap Sort"; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,66 @@ | |||||||
|  | package com.hithomelabs.princeton1.module8; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module4.Queue; | ||||||
|  | import com.hithomelabs.princeton1.module5.ComparableHelper; | ||||||
|  | 
 | ||||||
|  | import java.util.Iterator; | ||||||
|  | 
 | ||||||
|  | public class PriorityQueue<E> extends Queue<E> implements ComparableHelper { | ||||||
|  |     private int size; | ||||||
|  |     private E[] arr; | ||||||
|  |     private static final int CAPACITY = 100; | ||||||
|  |     private int capacity; | ||||||
|  | 
 | ||||||
|  |     public PriorityQueue(){ | ||||||
|  |         this(CAPACITY); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public PriorityQueue(int capacity){ | ||||||
|  |         arr = (E[]) new Object[capacity+1]; | ||||||
|  |         this.capacity = capacity; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isEmpty() { | ||||||
|  |         return size == 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public E dequeue() { | ||||||
|  |         if(isEmpty()) | ||||||
|  |             return null; | ||||||
|  |         E value = arr[1]; | ||||||
|  |         ComparableHelper.exch(arr, 1, size); | ||||||
|  |         arr[size--] = null; | ||||||
|  |         Heap.sink(arr, 1, size, null, null); | ||||||
|  |         return value; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void enqueue(E element) { | ||||||
|  |         arr[++size] = element; | ||||||
|  |         Heap.swim(arr, size, size, null, null); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public int size() { | ||||||
|  |         return size; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Iterator iterator() { | ||||||
|  |         return new Iterator() { | ||||||
|  | 
 | ||||||
|  |             int index = 1; | ||||||
|  |             @Override | ||||||
|  |             public boolean hasNext() { | ||||||
|  |                 return index <= size; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             @Override | ||||||
|  |             public Object next() { | ||||||
|  |                 return arr[index++]; | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,63 @@ | |||||||
|  | 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 a heap of a 100 random sized  with Comparator") | ||||||
|  |     public void testComparatorSort(){ | ||||||
|  |         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, Apple.COMPARE_BY_SIZE); | ||||||
|  |         apples.sort(Apple.COMPARE_BY_SIZE); | ||||||
|  |         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() { | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -11,6 +11,11 @@ plugins { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| rootProject.name = 'Pricenton1' | rootProject.name = 'Pricenton1' | ||||||
| include('module4') | include 'module4' | ||||||
| include 'clients' | include 'clients' | ||||||
|  | include 'module5' | ||||||
|  | include 'module6' | ||||||
|  | include 'common' | ||||||
|  | include 'module7' | ||||||
|  | include 'module8' | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user