JavaScript 中的最长递减子序列子数组
我们需要编写一个 JavaScript 函数,它的输入是一组整数。该函数应当返回该组整数中最长递减子序列的长度。
例如 −
如果输入数组是 −
const arr = [5, 2, 5, 4, 3, 2, 4, 6, 7];
则输出应当是 −
const output = 4;
因为最长递减子序列(连续单词)是 [5, 4, 3, 2];
示例
const arr = [5, 2, 5, 4, 3, 2, 4, 6, 7]; const decreasingSequence = (arr = []) => { let longest = []; let curr = []; const setDefault = (newItem) => { if (curr.length > longest.length) { longest = curr; } curr = [newItem]; }; for (const item of arr) { if (curr.length && item > curr[curr.length - 1]) { setDefault(item); } else { curr.push(item); } } setDefault(); return longest.length; }; console.log(decreasingSequence(arr));
输出
这会生成以下输出 −
4
广告