计算 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
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP