@extra-array/is-disjoint
Version:
Checks if arrays have no value in common.
41 lines (40 loc) • 963 B
JavaScript
;
function id(v) {
return v;
}
function cmp(a, b) {
return a < b ? -1 : (a > b ? 1 : 0);
}
function from$$1(x) {
return Array.isArray(x) ? x : [...x];
}
function from(vs, fm = null) {
return new Set(fm ? from$$1(vs).map(fm) : vs);
}
function isDisjointMap(x, y, fm = null) {
var s = from(y, fm);
var fm = fm || id, i = -1;
for (var u of x) {
var u1 = fm(u, ++i, x);
if (s.has(u1))
return false;
}
return true;
}
function isDisjointDual(x, y, fc = null, fm = null) {
var fc = fc || cmp, fm = fm || id;
var y1 = [...y].map(fm), i = -1;
for (var u of x) {
var u1 = fm(u, ++i, x);
for (var v1 of y1)
if (fc(u1, v1) === 0)
return false;
}
return true;
}
function isDisjoint(x, y, fc = null, fm = null) {
if (fc)
return isDisjointDual(x, y, fc, fm);
return isDisjointMap(x, y, fm);
}
module.exports = isDisjoint;