寻找嵌套数组中最大值 - JavaScript
假设我们在 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
广告