JavaScript中最长的递减子序列子数组
我们需要编写一个JavaScript函数,该函数接受一个Integer数组。该函数应返回数组中最长的递减子序列的长度。
例如-
如果输入数组是-
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
热门推荐
10 诗词送行祝福语大全简短
11 新房开工吉日祝福语简短
12 50多岁生日简短祝福语
13 安徽疫情祝福语简短英语
14 农民朋友发财祝福语简短
15 对生活祝福语简短精辟
16 搬家词简短祝福语朋友
17 女神结婚快乐祝福语简短
18 文学短句祝福语大全简短