mirror of
https://github.com/borbann-platform/end-of-semester-report.git
synced 2025-12-20 06:44:05 +01:00
59 lines
1.8 KiB
JavaScript
59 lines
1.8 KiB
JavaScript
'use strict';
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
|
|
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
|
|
|
|
exports.default = permutations;
|
|
|
|
var _config = require('./config');
|
|
|
|
var _config2 = _interopRequireDefault(_config);
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
function permutations(letters, trie) {
|
|
var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {
|
|
type: 'anagram'
|
|
};
|
|
|
|
if (typeof letters !== 'string') {
|
|
throw 'Permutations expects string letters, received ' + (typeof letters === 'undefined' ? 'undefined' : _typeof(letters));
|
|
}
|
|
|
|
var words = [];
|
|
|
|
var permute = function permute(word, node) {
|
|
var prefix = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
|
|
|
|
var wordIsEmpty = word.length === 0;
|
|
var wordFound = words.indexOf(prefix) !== -1;
|
|
var endWordFound = node[_config2.default.END_WORD] === 1;
|
|
|
|
if (wordIsEmpty && endWordFound && !wordFound) {
|
|
words.push(prefix);
|
|
}
|
|
|
|
for (var i = 0, len = word.length; i < len; i++) {
|
|
var letter = word[i];
|
|
|
|
if (opts.type === 'sub-anagram') {
|
|
if (endWordFound && !(words.indexOf(prefix) !== -1)) {
|
|
words.push(prefix);
|
|
}
|
|
}
|
|
|
|
if (node[letter]) {
|
|
var remaining = word.substring(0, i) + word.substring(i + 1, len);
|
|
permute(remaining, node[letter], prefix + letter, words);
|
|
}
|
|
}
|
|
|
|
return words.sort();
|
|
};
|
|
|
|
return permute(letters, trie);
|
|
};
|
|
module.exports = exports['default']; |