尝试使用javascript获取所有可能的组合

时间:2012-02-21 19:49:44

标签: javascript combinations

我目前仍然坚持这个问题,

假设有一个数组arr4(长度不固定)。 我需要找到其元素的所有组合。

预期输出为:

4-16D-5d 
4-16D-5e
4A-16D-5d
4A-16D-5e
4B-16D-5d
4B-16D-5e

4-15D-5d
4-15D-5e
4A-15D-5d
4A-15D-5e
4B-15D-5d
4B-15D-5e

我尝试的是:

arr4=[['4','4A','4B'],['16D','15D'],['5d','5e']]; //may contains more elements
alert("arr4 "+arr4);
for(var k=0;k<arr4.length;k++){
    alert("k "+k);
    arr_v=arr4[k]
    alert("arrv"+arr_v);
    alert ("arrv lengt"+arr_v.length);
    for(var z=0;z<arr_v.length;z++){
        m=1;
        while(m<arr4.length){
            var test=arr4[m];
            for(var n=0;n<test.length;n++)
                alert(arr_v[z]+"<TEST>"+test[n]);
        }
        m++;
    }
}   

我找到了一个解决方案:

function product() {
    return Array.prototype.reduce.call(arguments, function(as, bs) {
        return [a.concat(b) for each (a in as) for each (b in bs)]
    }, [[]]);
}

BUT

arr4=[['4','4A','4B'],['16D','15D'],['5d','5e']];
alert(product(['4','4A','4B'],['16D','15D'],['5d','5e']);

以上作品但以下不起作用:

arr4=[['4','4A','4B'],['16D','15D'],['5d','5e']];
alert(product(arr4);

任何人都建议一个解决方案

编辑:解决方案here

2 个答案:

答案 0 :(得分:2)

var arr4 = [['4','4A','4B'],['16D','15D'],['5d','5e']];
for(var a = 0; a < arr4[1].length; a++){
    if(a != 0){
        document.write('<br /><br />');
    }
    for(var b = 0; b < arr4[0].length; b++){
        for(var c = 0; c < arr4[2].length; c++){
            document.write(arr4[0][b] + '-' + arr4[1][a] + '-' + arr4[2][c] + '<br />')
        }
    }
}

显然你不想使用document.write但是在最后一个for循环中是每行输出将使用

arr4[0][b] + '-' + arr4[1][a] + '-' + arr4[2][b]

jsFiddle对那些感兴趣的人http://jsfiddle.net/5AmMU/1/

答案 1 :(得分:2)

您可以计算每个子阵列的笛卡尔积。见this question and its answer

我试了一下,因为它超出了每个数组的长度,无论每个列表中有多少元素,它都应该有效,并返回每个产品的列表。