码迷,mamicode.com
首页 > 编程语言 > 详细

js 数组全排列组合算法

时间:2017-12-11 23:06:26      阅读:315      评论:0      收藏:0      [点我收藏+]

标签:for   没有   ati   length   callback   val   循环   nat   使用   

function doCombination(arr) {
    var count = arr.length - 1; //数组长度(从0开始)
    var tmp = [];
    var totalArr = [];// 总数组

    return doCombinationCallback(arr, 0);//从第一个开始
    //js 没有静态数据,为了避免和外部数据混淆,需要使用闭包的形式
    function doCombinationCallback(arr, curr_index) {
        for(val of arr[curr_index]) {
            tmp[curr_index] = val;//以curr_index为索引,加入数组
            //当前循环下标小于数组总长度,则需要继续调用方法
            if(curr_index < count) {
                doCombinationCallback(arr, curr_index + 1);//继续调用
            }else{
                totalArr.push(tmp);//(直接给push进去,push进去的不是值,而是值的地址)
            }

            //js  对象都是 地址引用(引用关系),每次都需要重新初始化,否则 totalArr的数据都会是最后一次的 tmp 数据;
            oldTmp = tmp;
            tmp = [];
            for(index of oldTmp) {
                tmp.push(index);
            }
            }
            return totalArr;
    }
}
//测试数组
var arr = [
    [1,2,3,4,5],
    [a,b,c,d],
    [成功, 失败]
];
//调用方法
document.write(doCombination(arr));

 

js 数组全排列组合算法

标签:for   没有   ati   length   callback   val   循环   nat   使用   

原文地址:http://www.cnblogs.com/ImCehnyx/p/8025339.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!