🎚 Window-sliding insertion algorithm in JavaScript
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

47 lines
950 B

7 years ago
'use strict';
const isEq = require('@codefeathers/iseq');
7 years ago
const wrap = (f, ...x) => (...y) => f(...x, ...y);
class Slider {
constructor (options) {
this.windowSize = options.size;
7 years ago
this.prefer = options.prefer;
this.accepting = options.accepting;
}
slide (host, guest) {
7 years ago
const k = this.windowSize;
const get = {
val: 0,
next: () => ++get.val,
}
const startSliding = (window, i) => {
const firstMatch = host.findIndex(wrap(isEq, window[0]));
if(firstMatch !== -1) {
get.val = firstMatch;
if(window.every((item, j) => {
if(j === 0) return true;
return isEq(item, host[get.next()]);
})) return [ firstMatch, i ];
}
const nextI = i + 1;
const newWindow = guest.slice(nextI, nextI + k);
if(newWindow.length === k) return startSliding(newWindow, nextI);
7 years ago
return [ -1, -1 ];
7 years ago
};
const window = guest.slice(0, k);
return startSliding(window, 0);
7 years ago
}
};
module.exports = Slider;