我目前仍然坚持这个问题,
假设有一个数组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
答案 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
我试了一下,因为它超出了每个数组的长度,无论每个列表中有多少元素,它都应该有效,并返回每个产品的列表。