ran npm run tester and test files generated
This commit is contained in:
31
test/permuteAll/permuteAll.js
Normal file
31
test/permuteAll/permuteAll.js
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
const permuteAll = (input) => {
|
||||||
|
const result = [];
|
||||||
|
let inputState = input;
|
||||||
|
|
||||||
|
if (typeof input === 'string') {
|
||||||
|
inputState = input.split('');
|
||||||
|
} else if (typeof input === 'number') {
|
||||||
|
inputState = (input).toString().split('');
|
||||||
|
}
|
||||||
|
|
||||||
|
const permute = (arr, m = []) => {
|
||||||
|
if (arr.length === 0) {
|
||||||
|
result.push(m)
|
||||||
|
} else {
|
||||||
|
for (let i = 0; i < arr.length; i++) {
|
||||||
|
let curr = arr.slice();
|
||||||
|
let next = curr.splice(i, 1);
|
||||||
|
permute(curr.slice(), m.concat(next))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
permute(inputState);
|
||||||
|
|
||||||
|
return (typeof input === 'string')
|
||||||
|
? result.map(variant => variant.join(''))
|
||||||
|
: (typeof input === 'number')
|
||||||
|
? result.map(variant => parseFloat(variant.join('')))
|
||||||
|
: result;
|
||||||
|
}
|
||||||
|
module.exports = permuteAll;
|
||||||
13
test/permuteAll/permuteAll.test.js
Normal file
13
test/permuteAll/permuteAll.test.js
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
const test = require('tape');
|
||||||
|
const permuteAll = require('./permuteAll.js');
|
||||||
|
|
||||||
|
test('Testing permuteAll', (t) => {
|
||||||
|
//For more information on all the methods supported by tape
|
||||||
|
//Please go to https://github.com/substack/tape
|
||||||
|
t.true(typeof permuteAll === 'function', 'permuteAll is a Function');
|
||||||
|
//t.deepEqual(permuteAll(args..), 'Expected');
|
||||||
|
//t.equal(permuteAll(args..), 'Expected');
|
||||||
|
//t.false(permuteAll(args..), 'Expected');
|
||||||
|
//t.throws(permuteAll(args..), 'Expected');
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user