mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-06 01:18:23 +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 }
|
17
String/PermutateString.test.js
Normal file
17
String/PermutateString.test.js
Normal 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'))
|
||||
})
|
||||
})
|
Reference in New Issue
Block a user