计算 JavaScript 中二维数组中行和列中最大的数字
要求编写一个 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
广告