mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-05 16:26:47 +08:00
Add Algorithm String Permutation
This commit is contained in:
33
String/PermutateString.js
Normal file
33
String/PermutateString.js
Normal file
@ -0,0 +1,33 @@
|
||||
'use strict'
|
||||
|
||||
const permutate = (aString) => {
|
||||
if (typeof aString !== 'string' || !aString) {
|
||||
throw new Error('The arg must be a valid, non empty string')
|
||||
}
|
||||
const characters = aString.split('')
|
||||
let permutations = [[characters.shift()]]
|
||||
while (characters.length) {
|
||||
const currentCharacter = characters.shift()
|
||||
permutations = calculateCurrentCharacterPermutation(permutations, currentCharacter)
|
||||
}
|
||||
return permutations
|
||||
.map(character => character.join(''))
|
||||
.filter((item, index, self) => (self.indexOf(item) === index))
|
||||
.sort()
|
||||
}
|
||||
|
||||
const calculateCurrentCharacterPermutation = (allPermutations, currentCharacter) => {
|
||||
const currentPermutations = []
|
||||
allPermutations.map(permutation => {
|
||||
let index = 0
|
||||
while (index <= permutation.length) {
|
||||
const tmp = [...permutation]
|
||||
tmp.splice(index, 0, currentCharacter)
|
||||
currentPermutations.push(tmp)
|
||||
index++
|
||||
}
|
||||
})
|
||||
return currentPermutations
|
||||
}
|
||||
|
||||
export { permutate }
|
Reference in New Issue
Block a user