我应该从每个子数组返回一个包含最大数目的数组。这是我的代码:
function largestOfFour(arr) {
let largestNum = [0,0,0,0];
for (let i = 0; i < arr.length; i++) {
for (let j = 0; j < arr[i].length; j++) {
if (arr[i][j] > largestNum[i]) {
largestNum[i] = arr[i][j];
}
}
}
return largestNum;
}
largestOfFour([[4, 5, 1, 3],[13, 27, 18, 26],[32, 35, 37, 39],[1000, 1001, 857, 1]]);
我通过了除一项以外的所有测试。
largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]])
应返回一个数组。 通过
largestOfFour([[13, 27, 18, 26], [4, 5, 1, 3], [32, 35, 37, 39], [1000, 1001, 857, 1]])
应返回[27, 5, 39, 1001]
。
通过
largestOfFour([[4, 9, 1, 3], [13, 35, 18, 26], [32, 35, 97, 39], [1000000, 1001, 857, 1]])
应返回[9, 35, 97, 1000000]
。
largestOfFour([[17, 23, 25, 12], [25, 7, 34, 48], [4, -10, 18, 21], [-72, -3, -17, -10]])
应返回[25, 48, 21, -3]
。
失败
如果有人愿意告诉我我在做什么错,那将非常有帮助。谢谢
答案 0 :(得分:1)
您可以通过解构每个子数组来简单地使用Math.max
:
function largestOfFour(arr) {
return arr.map(subarr => Math.max(...subarr));
}
console.log(largestOfFour([[4, 5, 1, 3],[13, 27, 18, 26],[32, 35, 37, 39],[1000, 1001, 857, 1]]));
console.log(largestOfFour([[17, 23, 25, 12], [25, 7, 34, 48], [4, -10, 18, 21], [-72, -3, -17, -10]]));