我们需要编写一个JavaScript函数,该函数将二维整数数组作为唯一参数。
我们函数的任务是从数组中计算出在行和列中都最大的所有此类整数的计数。
然后,该函数应返回该计数。
例如-
如果输入数组是-
const arr = [ [21, 23, 22], [26, 26, 25], [21, 25, 27] ];
那么输出应该是-
const output = 3;
因为这三个数字分别是26、26、27
以下是代码-
const arr = [
[21, 23, 22],
[26, 26, 25],
[21, 25, 27]
];
const countGreatest = (matrix = []) => {
let rows = matrix.length;
if (rows == 0){
return 0;
};
let cols = matrix[0].length;
const colMax = [];
const rowMax = [];
let res = 0;
for (let r = 0; r < rows; ++ r) {
for (let c = 0; c < cols; ++ c) {
rowMax[r] = Math.max(rowMax[r] || 0, matrix[r][c]);
colMax[c] = Math.max(colMax[c] || 0, matrix[r][c]);
}
};
for (let r = 0; r < rows; ++ r) {
for (let c = 0; c < cols; ++ c) {
if (matrix[r][c] == rowMax[r] && matrix[r][c] == colMax[c]) {
res ++;
}
}
}
return res;
};
console.log(countGreatest(arr));输出结果以下是控制台输出-
3