1.1 KiB
1.1 KiB
title, tags
| title | tags |
|---|---|
| stringPermutations | string,recursion,advanced |
Generates all permutations of a string (contains duplicates).
- Use recursion.
- For each letter in the given string, create all the partial permutations for the rest of its letters.
- Use
Array.prototype.map()to combine the letter with each partial permutation, thenArray.prototype.reduce()to combine all permutations in one array. - Base cases are for string
lengthequal to2or1. - ⚠️ WARNING: This function's execution time increases exponentially with each character. Anything more than 8 to 10 characters will cause your browser to hang as it tries to solve all the different combinations.
const stringPermutations = str => {
if (str.length <= 2) return str.length === 2 ? [str, str[1] + str[0]] : [str];
return str
.split('')
.reduce(
(acc, letter, i) =>
acc.concat(stringPermutations(str.slice(0, i) + str.slice(i + 1)).map(val => letter + val)),
[]
);
};
stringPermutations('abc'); // ['abc','acb','bac','bca','cab','cba']