二维数组的子数组元素进行合并且不重复

版权声明:本文为博主原创文章,未经博主允许不得转载。 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);

猜你喜欢

转载自blog.csdn.net/yin_991/article/details/81490216