Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

การนับจำนวนมากที่สุดในแถวและคอลัมน์ในอาร์เรย์ 2 มิติใน 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