Add Algorithm String Permutation

This commit is contained in:
piemme
2020-10-11 19:00:38 +02:00
parent d23cd4acf0
commit 7aa9410c7a
2 changed files with 50 additions and 0 deletions

33
String/PermutateString.js Normal file
View 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 }

View File

@ -0,0 +1,17 @@
import { permutate } from './PermutateString'
describe('Permutate a string', () => {
it('expects to throw an Error with an empty string', () => {
expect(() => { permutate() }).toThrow('The arg must be a valid, non empty string')
})
it('expects to permute "no" into [no, on]', () => {
expect(['no', 'on']).toEqual(permutate('no'))
})
it('expects to permute "yes" into [esy, eys, sey, sye, yes, yse]', () => {
expect(['esy', 'eys', 'sey', 'sye', 'yes', 'yse']).toEqual(permutate('yes'))
})
it('expects to permute "good" into [dgoo dogo doog gdoo godo good odgo odog ogdo ogod oodg oogd ]', () => {
expect(['dgoo', 'dogo', 'doog', 'gdoo', 'godo', 'good', 'odgo', 'odog', 'ogdo', 'ogod', 'oodg', 'oogd'])
.toEqual(permutate('good'))
})
})