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

更新于: 25-11-2020

176 次浏览

开启你的 职业生涯

完成课程,获得认证

开始学习
广告