-
Notifications
You must be signed in to change notification settings - Fork 8
/
bsarray.js
66 lines (47 loc) · 1.34 KB
/
bsarray.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
58
59
60
61
62
63
64
65
66
'use strict';
module.exports = bsarray;
// really simple pseudo-bst array wrapper
function bsarray(compare) {
return new BSArray(compare);
}
function BSArray(compare) {
this.compare = compare || defaultCompare;
this.items = [];
}
function defaultCompare(a, b) {
return a < b ? -1 : a > b ? 1 : 0;
}
BSArray.prototype = {
insert: function (key, value) {
var items = this.items,
compare = this.compare,
i = 0,
j = items.length - 1;
while (i <= j) {
var mid = Math.floor((i + j) / 2);
var c = compare(key, items[mid].key);
if (c === 0) { items[mid].value = value; return; }
if (c < 0) j = mid - 1;
else i = mid + 1;
}
items.splice(i, 0, {key: key, value: value});
},
find: function (key) {
var items = this.items,
compare = this.compare,
i = 0,
j = items.length - 1;
while (i <= j) {
var mid = Math.floor((i + j) / 2);
var c = compare(key, items[mid].key);
if (c === 0) return mid;
if (c < 0) j = mid - 1;
else i = mid + 1;
}
return null;
},
remove: function (key) {
var index = this.find(key);
if (index !== null) this.items.splice(index, 1);
}
};