版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/yin_991/article/details/81490216
如果有三组数:['A1','A2','A3']、['B1','B2']、['C1','C2'],从每一组里抽出一个数并进行组合,且每种情况不同,一共有3*2*2=12种情况,这是很熟悉的数学题,如果用代码实现,应该如何做呢?其实我试过手写了一下代码,才发现手写的与在编辑器里边写边调试的体会很不一样,手写的感觉就是能边打草稿边思考,而调试的话能容易发现问题出在哪里然后也方面修改,很多时候也会带来一些写下去的灵感,各有各的好吧。我回到电脑上来写的时候,在浏览器控制台一步一步去console.log了一些东西出来,然后慢慢地就找到了一点点“出路”。
代码如下:
function sortT() {
var a=['A1','A2'];
var b=['B1','B2','B3'];
var c=['C1','C2'];
var arr=[a,b,c];
for(var i=0;i<arr[0].length;i++){
//A1 A2
for(var j=0; j<arr[1].length;j++){
//B1 B2
// console.log(a[i].concat(b[j]));
for(var k=0;k<arr[2].length;k++){
//C1 C2
console.log(arr[0][i].concat(arr[1][j],arr[2][k]))
}
}
}
}
sortT();
这样就可以实现12种情况了。
改为传参的方式:
function sortT(arr) {
for(var i=0;i<arr[0].length;i++){
//A1 A2
for(var j=0; j<arr[1].length;j++){
//B1 B2
// console.log(a[i].concat(b[j]));
for(var k=0;k<arr[2].length;k++){
//C1 C2
console.log(arr[0][i].concat(arr[1][j],arr[2][k]))
}
}
}
}
var a=['A1','A2'];
var b=['B1','B2','B3'];
var c=['C1','C2'];
var arr=[a,b,c];
sortT(arr);