Merge pull request #47 from jussisaurio/anagrams-functional
Make "Anagrams of string" fully functional
This commit is contained in:
@ -74,8 +74,7 @@ Base cases are for string `length` equal to `2` or `1`.
|
|||||||
const anagrams = str => {
|
const anagrams = str => {
|
||||||
if(str.length <= 2) return str.length === 2 ? [str, str[1] + str[0]] : [str];
|
if(str.length <= 2) return str.length === 2 ? [str, str[1] + str[0]] : [str];
|
||||||
return str.split('').reduce( (acc, letter, i) => {
|
return str.split('').reduce( (acc, letter, i) => {
|
||||||
anagrams(str.slice(0, i) + str.slice(i + 1)).map( val => acc.push(letter + val) );
|
return acc.concat(anagrams(str.slice(0, i) + str.slice(i + 1)).map( val => letter + val ));
|
||||||
return acc;
|
|
||||||
}, []);
|
}, []);
|
||||||
}
|
}
|
||||||
// anagrams('abc') -> ['abc','acb','bac','bca','cab','cba']
|
// anagrams('abc') -> ['abc','acb','bac','bca','cab','cba']
|
||||||
|
|||||||
@ -8,10 +8,8 @@ Base cases are for string `length` equal to `2` or `1`.
|
|||||||
```js
|
```js
|
||||||
const anagrams = str => {
|
const anagrams = str => {
|
||||||
if(str.length <= 2) return str.length === 2 ? [str, str[1] + str[0]] : [str];
|
if(str.length <= 2) return str.length === 2 ? [str, str[1] + str[0]] : [str];
|
||||||
return str.split('').reduce( (acc, letter, i) => {
|
return str.split('').reduce( (acc, letter, i) =>
|
||||||
anagrams(str.slice(0, i) + str.slice(i + 1)).map( val => acc.push(letter + val) );
|
acc.concat(anagrams(str.slice(0, i) + str.slice(i + 1)).map( val => letter + val )), []);
|
||||||
return acc;
|
|
||||||
}, []);
|
|
||||||
}
|
}
|
||||||
// anagrams('abc') -> ['abc','acb','bac','bca','cab','cba']
|
// anagrams('abc') -> ['abc','acb','bac','bca','cab','cba']
|
||||||
```
|
```
|
||||||
|
|||||||
Reference in New Issue
Block a user