使用JavaScript中的while循环查找最长的连续数字子数组
我们需要编写一个带有while语句的函数,该函数确定正整数数组中最大的连续子数组的长度。
例如-
如果输入数组是-
const input = [6, 7, 8, 6, 12, 1, 2, 3, 4] --> [1,2,3,4]
那么输出应该是-
4
如果输入数组是-
const input = [5, 6, 1, 8, 9, 7] --> [8,9]
那么输出应该是-
2
因此,让我们为该函数编写代码-
示例
const arr = [6, 7, 8, 6, 12, 1, 2, 3, 4]; const arr1 = [5, 6, 1, 8, 9, 7]; const findLongestSub = arr => { let count = 1, len = 0, max = 1; while(len < arr.length){ if(arr[len] === arr[len - 1] + 1){ count++; if(max < count){ max = count; } }else{ count = 1; }; len++; }; return max; }; console.log(findLongestSub(arr)); console.log(findLongestSub(arr1));
输出结果
控制台中的输出将为-
4 2