สมมติว่า เราต้องเขียนฟังก์ชันอย่างง่ายใน JavaScript ที่รับอาร์เรย์ของตัวเลขต่อไปนี้ (ซ้อนกับระดับใดก็ได้) -
const arr = [ 15, 24, [ 29, 85, 56, [ 36, 14, 6, 98, 34, 52 ], 22 ], 87, 60 ];
และคืนค่าจำนวนที่มากที่สุดในอาร์เรย์
ตัวอย่างเช่น
หากอาร์เรย์อินพุตเป็น −
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