-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathjavascript-array-sets.js
More file actions
120 lines (114 loc) · 2.73 KB
/
javascript-array-sets.js
File metadata and controls
120 lines (114 loc) · 2.73 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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
// Based ON: https://code.google.com/p/javascriptsets/
Array.prototype.cartesian = function(a) {
var temp = [];
for (var i = 0; i < this.length; i++) {
for (var j = 0; j < a.length; j++) {
temp.push([this[i], a[j]]);
}
}
return temp;
};
Array.prototype.complement = function(a) {
var keys = {};
var temp = [];
for (var i = 0; i < this.length; i++) {
keys[this[i]] = 1;
}
for (var i = 0; i < a.length; i++) {
if (keys[a[i]] != undefined) {
keys[a[i]]--;
}
}
for (var key in keys) {
if (keys[key] > 0) {
temp.push(key);
}
}
return temp;
};
Array.prototype.difference = function(a) {
var temp = [];
var keys = {};
for (var i = 0; i < this.length; i++) {
keys[this[i]] = 1;
}
for (var i = 0; i < a.length; i++) {
if (keys[a[i]] != undefined) {
keys[a[i]] = 2;
}
}
for (var key in keys) {
if (keys[key] == 1) {
temp.push(key);
}
}
return temp;
};
Array.prototype.intersection = function(a) {
var keys = {};
var temp = [];
var bigger = (this.length > a.length) ? this : a;
var smaller = (this.length > a.length) ? a : this;
for (var i = 0; i < smaller.length; i++) {
keys[smaller[i]] = 1;
}
for (var i = 0; i < bigger.length; i++) {
if (keys[bigger[i]] != undefined) {
keys[bigger[i]]++;
}
}
for (var key in keys) {
if (keys[key] > 1) {
temp.push(key);
}
}
return temp;
};
Array.prototype.powerset = function() {
// [x,y,z] => [[],[x],[y],[z],[x,y],[x,z],[y,z],[x,y,z]]
var temp = [];
var clone = [];
// iteration 0 - just add the empty set
temp.push([]);
// iteration 1 - add each individual element
for (var i = 0; i < this.length; i++) {
temp.push([this[i]]);
}
// iteration 2 - add each individual element, unioned with every other element
var clone = this.union([]);
while (clone.length > 0) {
var el = clone[0];
var others = clone.complement([el]);
for (var i = 0; i < others.length; i++) {
temp.push([el, others[i]]);
}
clone = others;
}
for (var i = 0; i < this.length; i++) {
// hmmmmmm, not quite....
}
// iteration 3 - add the original set
temp.push(this.union([]));
return temp;
};
Array.prototype.union = function(a) {
var keys = {};
var temp = [];
var bigger = (this.length > a.length) ? this : a;
var smaller = (this.length > a.length) ? a : this;
// build has table with smaller array
for (var i = 0; i < smaller.length; i++) {
keys[smaller[i]] = 1;
}
// loop over larger array checking hash table for matches
for (var i = 0; i < bigger.length; i++) {
if (keys[bigger[i]] == undefined) {
keys[bigger[i]] = 1;
}
}
// convert hash table to array and return
for (var key in keys) {
temp.push(key);
}
return temp;
};