end-of-semester-report/node_modules/trie-prefix-tree/dist/permutations.js
2025-05-14 16:14:35 +07:00

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'];