计算 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

更新日期:2021 年 1 月 23 日

388 次浏览

开启你的 职业生涯

通过完成此课程获得认证

入门指南
广告