Compare commits

...

11 Commits

Author SHA1 Message Date
38de5fe0a5 priority queue implementation added (#20)
All checks were successful
sample gradle build and test / build (push) Successful in 1m0s
Reviewed-on: Hithomelabs/Princeton1#20
Reviewed-by: hitanshu <hitanshu98@gmail.com>
Co-authored-by: Kruti Shah <krutis0201@gmail.com>
Co-committed-by: Kruti Shah <krutis0201@gmail.com>
2025-02-19 21:55:20 +00:00
8c47ac248c Adding benchmarking code (#17)
All checks were successful
sample gradle build and test / build (push) Successful in 52s
Reviewed-on: Hithomelabs/Princeton1#17
Reviewed-by: kruti <krutis0201@gmail.com>
Co-authored-by: hitanshu310 <hitanshu98@gmail.com>
Co-committed-by: hitanshu310 <hitanshu98@gmail.com>
2025-02-19 19:53:59 +00:00
bbc040dcd4 Heapsort Implementation
All checks were successful
sample gradle build and test / build (pull_request) Successful in 2m16s
sample gradle build and test / build (push) Successful in 55s
2025-02-16 16:40:56 +05:30
6a752c9dc2 Adding quick sort
All checks were successful
sample gradle build and test / build (pull_request) Successful in 57s
sample gradle build and test / build (push) Successful in 53s
2025-02-08 01:57:32 +05:30
90f8b14ee5 Mode commonly used objects to a new module common, added dependencies and test dependencies for other modules on common, added Merge sort, client and tests
All checks were successful
sample gradle build and test / build (pull_request) Successful in 55s
sample gradle build and test / build (push) Successful in 49s
2025-02-04 02:15:31 +05:30
178f0461ee .gitignore changes
All checks were successful
sample gradle build and test / build (pull_request) Successful in 53s
sample gradle build and test / build (push) Successful in 47s
2025-02-02 14:01:08 +05:30
a4ccbee99c Added a lot of stuff
All checks were successful
sample gradle build and test / build (pull_request) Successful in 1m14s
sample gradle build and test / build (push) Successful in 4m10s
2025-02-02 01:12:22 +05:30
3c3eee2e4d Adding shell sort and other test cases
All checks were successful
sample gradle build and test / build (pull_request) Successful in 8m8s
2025-02-02 01:00:10 +05:30
f0b577b5f6 Fixing failed build
All checks were successful
sample gradle build and test / build (pull_request) Successful in 7m25s
2025-02-01 16:42:42 +05:30
7ba2d22e43 Insertion sort and selection sort with test cases
Some checks failed
sample gradle build and test / build (pull_request) Failing after 1m18s
2025-02-01 16:34:39 +05:30
fdca30f50a Adding tests and modifying roadmap
All checks were successful
sample gradle build and test / build (pull_request) Successful in 1m35s
2025-01-30 01:59:32 +05:30
75 changed files with 2137 additions and 22 deletions

View File

@ -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
View File

@ -3,3 +3,4 @@
# Ignore Gradle build output directory # Ignore Gradle build output directory
build build
bin

4
.idea/gradle.xml generated
View File

@ -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
View 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>

View 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>

View File

@ -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"
]
} }

View File

@ -1,10 +1,18 @@
#Data Structures # Data Structures
1. Stacks: 1. Stacks:
- Linear data structure - [API](../module4/src/main/java/com/hithomelabs/princeton1/module4/Stack.java)
- Can have various implementations - [Sample client](../clients/src/main/java/com/hithomelabs/clients/ArrayStackClient.java)
- Should support (LIFO) - Linear data structure
- Primitive implementation (Using arrays of primitive data types) - Can have various implementations
- Other implementations (Using linked lists) - Should support (LIFO)
2. Queues: - [Primitive implementation](../module4/src/main/java/com/hithomelabs/princeton1/module4/ArrayStack.java) (Using arrays of primitive data types)
- [Other implementations](../module4/src/main/java/com/hithomelabs/princeton1/module4/LinkedStack.java) (Using linked lists)
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
View 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 |

View File

@ -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 {

View File

@ -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";
}
}

View File

@ -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();
}
}

View File

@ -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();
}
}

View File

@ -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() + " |" );
}
}
}

View File

@ -0,0 +1,8 @@
package com.hithomelabs.clients.Benchmarks;
public interface Sortable<E> {
public E[] getArray();
public String getOrdering();
}

View File

@ -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";
}
}

View File

@ -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";
}
}

View File

@ -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";
}
}

View File

@ -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";
}
}

View File

@ -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";
}
}

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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]);
}
}

View File

@ -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;
}
}
}

View File

@ -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]);
}
}

View File

@ -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]);
}
}

View File

@ -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]);
}
}

View File

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

View File

@ -0,0 +1,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]);
}
}

View File

@ -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
View 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()
}

View File

@ -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;
}
}

View File

@ -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;
}
}

View File

@ -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

View File

@ -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);
} }

View File

@ -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

View File

@ -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);
}
}

View File

@ -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);
}
}

View File

@ -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
View 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()
}

View File

@ -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;}
}

View File

@ -0,0 +1,7 @@
package com.hithomelabs.princeton1.module5;
public interface ComparableSort<E> {
void sort(E[] arr);
}

View File

@ -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;
}
}

View File

@ -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);
}

View File

@ -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";
}
}

View File

@ -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);
}
}

View File

@ -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);
}

View File

@ -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";
}
}

View File

@ -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";
}
}

View File

@ -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;
}
}

View File

@ -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
View 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()
}

View File

@ -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";
}
}

View File

@ -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
View 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()
}

View File

@ -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";
}
}

View File

@ -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";
}
}

View File

@ -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;
}
}

View File

@ -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
View 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()
}

View File

@ -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;
}
}
}

View File

@ -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";
}
}

View File

@ -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++];
}
};
}
}

View File

@ -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() {
}
}

View File

@ -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'