JavaScript中二维数组转置

二维数组转置是指将二维数组横向元素保存为纵向元素

转置前arr    [                                          转置后res  [
                             ['a','b','c'],                                            ['a','d','g','j']
                             ['d','e','f'],                                             ['b','e','h','k']
                             ['g','h','i'],                                             ['c','f','i','l']
                             ['j','k','l']                                        ]
                 ]

 通过观察分析,可以发现如下规律

res[0][0] = arr[0][0]

res[0][1] = arr[1][0]

res[0][2] = arr[2][0]

res[0][3] = arr[3][0]

根据这个规律,可以得出而二维数组的转置公式为res[i][j] = arr[j][i],且res数组的长度等于arr元素的长度,res元素的长度等于arr数组的长度;代码如下:

	var arr =[ ['a','b','c'],['d','e','f'],  ['g','h','i'],['j','k','l']  ];
	var res =[];							//创建一个空数组
	for(var i=0;i<arr[0].length;i++){       //外层循环3次 对应转置后的数组res的长度 res.length
	    res[i] = [];     			 		// 将转置后的每一个元素设置为数组
		for(var j=0;j<arr.length;j++){     //内层循环4次  对应转置后数组res每个元素的长度
			res[i][j] = arr[j][i];         //为二维数组赋值
					}
				}
				console.log(res);

运行结果如下:

 

 

### JavaScript 中二数组转置的实现 在 JavaScript 中,可以通过嵌套 `for` 循环来实现二维数组转置。以下是具体的实现方式: #### 方法描述 给定一个二维数组 `arr`,其大小为 `m×n`(即有 `m` 行和 `n` 列),目标是将其转换为一个新的二维数组 `res`,其中新数组的大小为 `n×m`,并且满足条件 `res[i][j] = arr[j][i]`。 #### 实现代码 以下是一个完整的代码示例[^2]: ```javascript var arr = [ ['a', 'b', 'c'], ['d', 'e', 'f'], ['g', 'h', 'i'], ['j', 'k', 'l'] ]; // 创建一个空数组用于存储转置后的结果 var res = []; // 外层循环遍历原数组的第一索引范围 for (var i = 0; i < arr[0].length; i++) { // 初始化每一行为空数组 res[i] = []; // 内层循环遍历原数组的第二索引范围 for (var j = 0; j < arr.length; j++) { // 将原数组中的元素按转置规则赋值到新数组中 res[i][j] = arr[j][i]; } } console.log(res); ``` 运行上述代码后,变量 `res` 的内容将是转置后的二维数组。 #### 输出结果 对于输入数组 `arr`: ```javascript [ ['a', 'b', 'c'], ['d', 'e', 'f'], ['g', 'h', 'i'], ['j', 'k', 'l'] ] ``` 输出的结果 `res` 如下: ```javascript [ ['a', 'd', 'g', 'j'], ['b', 'e', 'h', 'k'], ['c', 'f', 'i', 'l'] ] ``` #### 注意事项 1. 如果原始二维数组不规则(即某些子数组的长度不同),则需要额外处理边界情况。 2. 可以通过更简洁的方式使用 ES6 的语法完成相同功能,例如利用 `map()` 和解构表达式[^2]。 ##### 使用 ES6 的简化版本 ```javascript const arr = [ ['a', 'b', 'c'], ['d', 'e', 'f'], ['g', 'h', 'i'], ['j', 'k', 'l'] ]; const res = arr[0].map((_, colIndex) => arr.map(row => row[colIndex])); console.log(res); ``` 此方法同样会得到相同的转置结果。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值