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

การตรวจจับองค์ประกอบที่ใหญ่ที่สุดในอาร์เรย์ของตัวเลข (ซ้อนกัน) ใน JavaScript


เราต้องเขียนฟังก์ชันอย่างง่ายใน JavaScript ที่รับอาร์เรย์ของ Numbers (ซ้อนกับระดับใดก็ได้) และคืนค่าจำนวนที่มากที่สุดในอาร์เรย์

ตัวอย่างเช่น หากอาร์เรย์อินพุตเป็น −

const arr = [
   34, 65, 67,
   [
      43, 76, 87, 23, 56, 7,
      [
         54, 7, 87, 23, 79, 994, 2
      ],
      54
   ], 54, 4, 2
];

จากนั้นผลลัพธ์ควรเป็น −

994

เราจะใช้การเรียกซ้ำเพื่อค้นหาจำนวนที่มากที่สุดในอาร์เรย์

ตัวอย่าง

รหัสสำหรับสิ่งนี้จะเป็น −

const arr = [
   34, 65, 67,
   [
      43, 76, 87, 23, 56, 7,
      [
         54, 7, 87, 23, 79, 994, 2
      ],
      54
   ], 54, 4, 2
];
const getGreatest = (arr, greatest = -Infinity) => {
   for(let i = 0; i < arr.length; i++){
      if(Array.isArray(arr[i])){
         return getGreatest(arr[i], greatest);
      };
      if(arr[i] > greatest){
         greatest = arr[i];
      }
   };
   return greatest;
};
console.log(getGreatest(arr));

ผลลัพธ์

ผลลัพธ์ในคอนโซลจะเป็น -

994