我正在尝试阅读一些用ruby编写的代码。我精通JavaScript,并且想了解代码在javascript中的含义。
代码如下:
def two_d_translate(arr)
new_arr = []
arr.each do |subArray|
ele = subArray[0]
num = subArray[1]
num.times { new_arr << ele }
end
return new_arr
end
代码的目的是通过将字符串打印成与它旁边的数字相同的次数将二维数组转换为一维数组,字符串是每个子数组中的第二个元素。
我用它来模仿它,但是我想知道是否还有其他更好的东西。
function two_d_translate(arr) {
let newArr = '';
let array = [];
for (let i = 0; i < arr.length; i++) {
for (let j = 0; j < arr[i].length; j += 2) {
let ele = arr[i][j];
let num = arr[i][j+1];
if (num === 0){
continue;
}
array[i] = Array(num).fill(ele);
}
}
newArr = array.toString().split(',');
return newArr;
}
对于这个测试样本,这似乎很酷。
arr_1 = [
['boot', 3],
['camp', 2],
['program', 0]
]
console.log(two_d_translate(arr_1));
这将产生预期的输出
[ 'boot', 'boot', 'boot', 'camp', 'camp' ]
但在这种情况下不会
arr_1=[
['boot', 3],
['camp', 0],
['program', 2]
]
这将导致不期望的输出
[ 'boot', 'boot', 'boot', '', 'program', 'program' ]
答案 0 :(得分:3)
使用Array#reduce
,您可以遍历整个数组,同时将最后的计算推入/合并为最终结果。结合Array.fill
,我们可以创建正确数量的字符串,有时为0。借助Array#concat
,我们可以轻松地将此3D数组转换为2D数组。这是一个示例:
function translateTo2D(arr) {
return arr.reduce((result, [name, count]) =>
result.concat(Array(count).fill(name)),
[]);
}
const arr = [['a', 2], ['b', 0], ['c', 1]];
console.log(translateTo2D(arr));
答案 1 :(得分:2)
如果您的环境允许使用扩展语法,则可以执行以下操作
const arr_1 = [
['boot', 3],
['camp', 0],
['program', 2]
]
const result = arr_1.reduce((acc, [string, times]) => [...acc, ...Array(times).fill(string)], []);
console.log(result); // [ 'boot', 'boot', 'boot', 'program', 'program' ]
答案 2 :(得分:2)
诀窍是使用flatMap
将单独的运行合并在一起:
let translate = a => a.flatMap(([s, n]) => Array(n).fill(s))
console.log(translate([
['boot', 3],
['camp', 2],
['program', 1]
]))
如果您的目标尚不支持flatMap
,则等效的ES6习惯用法是[].concat(...map)
:
let translate = a => [].concat(...a.map(([s, n]) => Array(n).fill(s)))
console.log(translate([
['boot', 3],
['camp', 2],
['program', 1]
]))
根据经验,在将“许多事物”转换为“许多事物”时使用map/flatMap
,将“许多事物”转换为“一件事物”时使用reduce
。