Merge pull request #500 from lq920320/Development

add Test for InsertionSort
This commit is contained in:
Varun Upadhyay 2018-08-29 17:46:25 -07:00 committed by GitHub
commit e4827bdb23
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 54 additions and 30 deletions

View File

@ -0,0 +1,27 @@
package src.main.java.com.sorts;
public class InsertionSort {
/**
* This method implements the Generic Insertion Sort
* Sorts the array in increasing order
*
* @param array The array to be sorted
**/
public <T extends Comparable<T>> T[] sort(T[] array) {
for (int j = 1; j < array.length; j++) {
// Picking up the key(Card)
T key = array[j];
int i = j - 1;
while (i >= 0 && SortUtils.less(key, array[i])) {
array[i + 1] = array[i];
i--;
}
// Placing the key (Card) at its correct position in the sorted subarray
array[i + 1] = key;
}
return array;
}
}

View File

@ -5,23 +5,18 @@ import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import src.main.java.com.sorts.BubbleSort; import src.main.java.com.sorts.BubbleSort;
import java.util.Arrays;
public class BubbleSortTest { public class BubbleSortTest {
@Test @Test
public void bubbleSortTest() { public void bubbleSortTest() {
BubbleSort bubbleSort = new BubbleSort(); BubbleSort bubbleSort = new BubbleSort();
Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7}; Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7};
Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(Arrays.toString(bubbleSort.sort(unsortedInt)));
Assert.assertArrayEquals(sortedInt, bubbleSort.sort(unsortedInt)); Assert.assertArrayEquals(sortedInt, bubbleSort.sort(unsortedInt));
Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'}; Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'};
Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'}; Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};
System.out.println(Arrays.toString(bubbleSort.sort(unsortedChar)));
Assert.assertArrayEquals(sortedChar, bubbleSort.sort(unsortedChar)); Assert.assertArrayEquals(sortedChar, bubbleSort.sort(unsortedChar));
} }

View File

@ -5,23 +5,18 @@ import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import src.main.java.com.sorts.HeapSort; import src.main.java.com.sorts.HeapSort;
import java.util.Arrays;
public class HeapSortTest { public class HeapSortTest {
@Test @Test
public void heapSortTest() { public void heapSortTest() {
HeapSort heapSort = new HeapSort(); HeapSort heapSort = new HeapSort();
Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7}; Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7};
Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(Arrays.toString(heapSort.sort(unsortedInt)));
Assert.assertArrayEquals(sortedInt, heapSort.sort(unsortedInt)); Assert.assertArrayEquals(sortedInt, heapSort.sort(unsortedInt));
Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'}; Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'};
Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'}; Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};
System.out.println(Arrays.toString(heapSort.sort(unsortedChar)));
Assert.assertArrayEquals(sortedChar, heapSort.sort(unsortedChar)); Assert.assertArrayEquals(sortedChar, heapSort.sort(unsortedChar));
} }
} }

View File

@ -0,0 +1,22 @@
package src.test.java.com.sorts;
import org.junit.Assert;
import org.junit.Test;
import src.main.java.com.sorts.InsertionSort;
public class InsertionSortTest {
@Test
public void insertionSortTest() {
InsertionSort insertionSort = new InsertionSort();
Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7};
Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
Assert.assertArrayEquals(sortedInt, insertionSort.sort(unsortedInt));
Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'};
Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};
Assert.assertArrayEquals(sortedChar, insertionSort.sort(unsortedChar));
}
}

View File

@ -5,23 +5,18 @@ import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import src.main.java.com.sorts.QuickSort; import src.main.java.com.sorts.QuickSort;
import java.util.Arrays;
public class QuickSortTest { public class QuickSortTest {
@Test @Test
public void quickSortTest() { public void quickSortTest() {
QuickSort quickSort = new QuickSort(); QuickSort quickSort = new QuickSort();
Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7}; Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7};
Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(Arrays.toString(quickSort.sort(unsortedInt)));
Assert.assertArrayEquals(sortedInt, quickSort.sort(unsortedInt)); Assert.assertArrayEquals(sortedInt, quickSort.sort(unsortedInt));
Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'}; Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'};
Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'}; Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};
System.out.println(Arrays.toString(quickSort.sort(unsortedChar)));
Assert.assertArrayEquals(sortedChar, quickSort.sort(unsortedChar)); Assert.assertArrayEquals(sortedChar, quickSort.sort(unsortedChar));
} }
} }

View File

@ -4,23 +4,18 @@ import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import src.main.java.com.sorts.SelectionSort; import src.main.java.com.sorts.SelectionSort;
import java.util.Arrays;
public class SelectionSortTest { public class SelectionSortTest {
@Test @Test
public void selectionSortTest() { public void selectionSortTest() {
SelectionSort selectionSort = new SelectionSort(); SelectionSort selectionSort = new SelectionSort();
Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7}; Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7};
Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(Arrays.toString(selectionSort.sort(unsortedInt)));
Assert.assertArrayEquals(sortedInt, selectionSort.sort(unsortedInt)); Assert.assertArrayEquals(sortedInt, selectionSort.sort(unsortedInt));
Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'}; Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'};
Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'}; Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};
System.out.println(Arrays.toString(selectionSort.sort(unsortedChar)));
Assert.assertArrayEquals(sortedChar, selectionSort.sort(unsortedChar)); Assert.assertArrayEquals(sortedChar, selectionSort.sort(unsortedChar));
} }
} }

View File

@ -4,23 +4,18 @@ import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import src.main.java.com.sorts.ShellSort; import src.main.java.com.sorts.ShellSort;
import java.util.Arrays;
public class ShellSortTest { public class ShellSortTest {
@Test @Test
public void shellSortTest() { public void shellSortTest() {
ShellSort shellSort = new ShellSort(); ShellSort shellSort = new ShellSort();
Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7}; Integer[] unsortedInt = new Integer[]{0, 5, 9, 2, 1, 3, 4, 8, 6, 7};
Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; Integer[] sortedInt = new Integer[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(Arrays.toString(shellSort.sort(unsortedInt)));
Assert.assertArrayEquals(sortedInt, shellSort.sort(unsortedInt)); Assert.assertArrayEquals(sortedInt, shellSort.sort(unsortedInt));
Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'}; Character[] unsortedChar = new Character[]{'f', 'h', 'c', 'a', 'b', 'd', 'g', 'e'};
Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'}; Character[] sortedChar = new Character[]{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};
System.out.println(Arrays.toString(shellSort.sort(unsortedChar)));
Assert.assertArrayEquals(sortedChar, shellSort.sort(unsortedChar)); Assert.assertArrayEquals(sortedChar, shellSort.sort(unsortedChar));
} }
} }