JavaScript实现穷举排列(permutation)算法谜题解答
作者:bea
谜题 穷举一个数组中各个元素的排列 策略 减而治之、递归 JavaScript解 代码如下: /** * Created by cshao on 12/23/14. */ function getPermutation(arr) { if (arr.length == 1) { return [arr]; } var permutation = []; for (var i=0; i<arr.length; i++) { var f
谜题
穷举一个数组中各个元素的排列
策略
减而治之、递归
JavaScript解
代码如下:
/**
* Created by cshao on 12/23/14.
*/
function getPermutation(arr) { if (arr.length == 1) { return [arr]; }
var permutation = []; for (var i=0; i<arr.length; i++) { var firstEle = arr[i]; var arrClone = arr.slice(0); arrClone.splice(i, 1); var childPermutation = getPermutation(arrClone); for (var j=0; j<childPermutation.length; j++) { childPermutation[j].unshift(firstEle); } permutation = permutation.concat(childPermutation); } return permutation; }
var permutation = getPermutation(['a','b','c']); console.dir(permutation);
结果
代码如下:
[ [ 'a', 'b', 'c' ],
[ 'a', 'c', 'b' ],
[ 'b', 'a', 'c' ],
[ 'b', 'c', 'a' ],
[ 'c', 'a', 'b' ],
[ 'c', 'b', 'a' ] ]
有用 | 无用
穷举一个数组中各个元素的排列
策略
减而治之、递归
JavaScript解
代码如下:
/**
* Created by cshao on 12/23/14.
*/
function getPermutation(arr) { if (arr.length == 1) { return [arr]; }
var permutation = []; for (var i=0; i<arr.length; i++) { var firstEle = arr[i]; var arrClone = arr.slice(0); arrClone.splice(i, 1); var childPermutation = getPermutation(arrClone); for (var j=0; j<childPermutation.length; j++) { childPermutation[j].unshift(firstEle); } permutation = permutation.concat(childPermutation); } return permutation; }
var permutation = getPermutation(['a','b','c']); console.dir(permutation);
结果
代码如下:
[ [ 'a', 'b', 'c' ],
[ 'a', 'c', 'b' ],
[ 'b', 'a', 'c' ],
[ 'b', 'c', 'a' ],
[ 'c', 'a', 'b' ],
[ 'c', 'b', 'a' ] ]
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- jQuery中:eq()选择器用法实例
- 根据配置文件加载js依赖模块
- JavaScript中的console.dir()函数介绍
- JavaScript中的console.group()函数详细介绍
- 小米公司JavaScript面试题
- 谷歌浏览器调试JavaScript小技巧
- JavaScript中的console.trace()函数介绍
- JavaScript中的console.profile()函数详细介绍
- jQuery中element选择器用法实例
- JavaScript中的console.time()函数详细介绍
- JavaScript前端图片加载管理器imagepool使用详解
- JavaScript版的TwoQueues缓存模型
- 浅谈重写window对象的方法
- JavaScript中的console.log()函数详细介绍
- 深入分析原生JavaScript事件
- JavaScript中的alert()函数使用技巧详解
- JavaScript实现三阶幻方算法谜题解答
- 浅谈JavaScript Date日期和时间对象
- jQuery中clearQueue()方法用法实例