forked from TheAlgorithms/Java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathNearestElementTest.java
More file actions
51 lines (51 loc) · 2.09 KB
/
NearestElementTest.java
File metadata and controls
51 lines (51 loc) · 2.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package datastructures.stacks;
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
import org.junit.jupiter.api.Test;
class NearestElementTest {
@Test
void testNearestGreaterToRight_basic() {
int[] arr = {4, 5, 2, 25};
int[] expected = {5, 25, 25, -1};
assertArrayEquals(expected, NearestElement.nearestGreaterToRight(arr));
}
@Test
void testNearestGreaterToLeft_basic() {
int[] arr = {4, 5, 2, 25};
int[] expected = {-1, -1, 5, -1};
assertArrayEquals(expected, NearestElement.nearestGreaterToLeft(arr));
}
@Test
void testNearestSmallerToRight_basic() {
int[] arr = {4, 5, 2, 25};
int[] expected = {2, 2, -1, -1};
assertArrayEquals(expected, NearestElement.nearestSmallerToRight(arr));
}
@Test
void testNearestSmallerToLeft_basic() {
int[] arr = {4, 5, 2, 25};
int[] expected = {-1, 4, -1, 2};
assertArrayEquals(expected, NearestElement.nearestSmallerToLeft(arr));
}
@Test
void testEdgeCases_emptyAndSingle() {
int[] empty = {};
int[] single = {10};
assertArrayEquals(new int[]{}, NearestElement.nearestGreaterToRight(empty));
assertArrayEquals(new int[]{-1}, NearestElement.nearestGreaterToRight(single));
assertArrayEquals(new int[]{-1}, NearestElement.nearestGreaterToLeft(single));
assertArrayEquals(new int[]{-1}, NearestElement.nearestSmallerToRight(single));
assertArrayEquals(new int[]{-1}, NearestElement.nearestSmallerToLeft(single));
}
@Test
void testDuplicates() {
int[] arr = {2, 2, 2};
int[] ngr = {-1, -1, -1}; // strictly greater required
int[] ngl = {-1, -1, -1};
int[] nsr = {-1, -1, -1}; // strictly smaller required
int[] nsl = {-1, -1, -1};
assertArrayEquals(ngr, NearestElement.nearestGreaterToRight(arr));
assertArrayEquals(ngl, NearestElement.nearestGreaterToLeft(arr));
assertArrayEquals(nsr, NearestElement.nearestSmallerToRight(arr));
assertArrayEquals(nsl, NearestElement.nearestSmallerToLeft(arr));
}
}