|
| 1 | +package com.thealgorithms.sorts; |
| 2 | + |
| 3 | +import static org.junit.jupiter.api.Assertions.assertEquals; |
| 4 | +import static org.junit.jupiter.api.Assertions.assertTrue; |
| 5 | + |
| 6 | +import java.util.HashMap; |
| 7 | +import java.util.Map; |
| 8 | +import java.util.stream.Stream; |
| 9 | +import org.junit.jupiter.params.ParameterizedTest; |
| 10 | +import org.junit.jupiter.params.provider.MethodSource; |
| 11 | + |
| 12 | +public class WaveSortTest { |
| 13 | + @ParameterizedTest |
| 14 | + @MethodSource("arraysToWaveSort") |
| 15 | + public void waveSortTest(Integer[] array) { |
| 16 | + WaveSort waveSort = new WaveSort(); |
| 17 | + final var inputHistogram = getHistogram(array); |
| 18 | + final var sortedArray = waveSort.sort(array); |
| 19 | + assertTrue(waveSort.isWaveSorted(sortedArray)); |
| 20 | + final var sortedHistogram = getHistogram(sortedArray); |
| 21 | + assertEquals(inputHistogram, sortedHistogram, "Element counts do not match"); |
| 22 | + } |
| 23 | + |
| 24 | + private Map<Integer, Integer> getHistogram(Integer[] array) { |
| 25 | + Map<Integer, Integer> histogram = new HashMap<>(); |
| 26 | + for (final var element : array) { |
| 27 | + histogram.put(element, histogram.getOrDefault(element, 0) + 1); |
| 28 | + } |
| 29 | + return histogram; |
| 30 | + } |
| 31 | + |
| 32 | + private static Stream<Object[]> arraysToWaveSort() { |
| 33 | + return Stream.of(new Object[] {new Integer[] {7, 7, 11, 3, 4, 5, 15}}, new Object[] {new Integer[] {1, 2, 3, 4, 5, 6, 7, 8}}, new Object[] {new Integer[] {8, 7, 6, 5, 4, 3, 2, 1}}, new Object[] {new Integer[] {3, 3, 3, 3}}, new Object[] {new Integer[] {-1, -3, -2, -4, -6, -5}}, |
| 34 | + new Object[] {new Integer[] {5, 3, 1, 2, 9, 7, 6, 8, 4, 0}}, new Object[] {new Integer[] {1}}, new Object[] {new Integer[] {2, 1}}, new Object[] {new Integer[] {1, 2}}, new Object[] {new Integer[] {}}, new Object[] {new Integer[] {0, 5, -3, 2, -1, 4, -2, 1, 3}}); |
| 35 | + } |
| 36 | + |
| 37 | + @ParameterizedTest |
| 38 | + @MethodSource("waveSortedArrays") |
| 39 | + public <T extends Comparable<T>> void testIsWaveSorted(T[] array, boolean expected) { |
| 40 | + final WaveSort waveSort = new WaveSort(); |
| 41 | + assertEquals(expected, waveSort.isWaveSorted(array)); |
| 42 | + } |
| 43 | + public static Stream<Object[]> waveSortedArrays() { |
| 44 | + return Stream.of(new Object[] {new Integer[] {3, 1, 4, 2, 5}, Boolean.TRUE}, new Object[] {new Integer[] {3, 1, 4, 2}, Boolean.TRUE}, new Object[] {new Integer[] {1, 3, 2, 4, 5}, Boolean.FALSE}, new Object[] {new Integer[] {4, 3, 5, 2, 3, 1, 2}, Boolean.TRUE}, |
| 45 | + new Object[] {new Integer[] {10, 90, 49, 2, 1, 5, 23}, Boolean.FALSE}, new Object[] {new Integer[] {}, Boolean.TRUE}, new Object[] {new Integer[] {1}, Boolean.TRUE}, new Object[] {new Integer[] {2, 1}, Boolean.TRUE}, new Object[] {new Integer[] {4, 3, 2, 5}, Boolean.FALSE}, |
| 46 | + new Object[] {new Double[] {4.0, 3.0, 5.1, 2.1, 3.3, 1.1, 2.2}, Boolean.TRUE}, new Object[] {new Double[] {10.1, 2.0, 2.0}, Boolean.TRUE}, new Object[] {new String[] {"a", "b", "c", "d"}, Boolean.FALSE}, new Object[] {new String[] {"b", "a", "b", "a", "b"}, Boolean.TRUE}); |
| 47 | + } |
| 48 | +} |
0 commit comments