-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathfind-low-high-index.js
57 lines (46 loc) · 1.21 KB
/
find-low-high-index.js
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
52
53
54
55
56
57
let findLowIndex = function(arr, key) {
let low = 0;
let high = arr.length - 1;
let mid = Math.floor(high / 2);
while (low <= high) {
let mid_elem = arr[mid];
if (mid_elem < key) {
low = mid + 1;
} else {
high = mid - 1;
}
mid = low + Math.floor((high - low) / 2);
}
if (low < arr.length && arr[high] === key) {
return low;
}
return -1;
};
let findHighIndex = function(arr, key) {
let low = 0;
let high = arr.length - 1;
let mid = Math.floor(high / 2);
while (low <= high) {
let mid_elem = arr[mid];
if (mid_elem <= key) {
low = mid + 1;
} else {
high = mid - 1;
}
mid = low + Math.floor((high - low) / 2);
}
if (high === -1){
return high
}
if (high < arr.length && arr[high] === key) {
return high;
}
return -1;
};
let array = [1, 1, 1, 2, 2, 2, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 6, 6, 6, 6];
var key = 5;
console.log("Low Index of " + key + ": " + (findLowIndex(array, key)));
console.log("High Index of " + key + ": " + (findHighIndex(array, key)));
key = -2;
console.log("Low Index of " + key + ": " + (findLowIndex(array, key)));
console.log("High Index of " + key + ": " + (findHighIndex(array, key)));