数组的最长递减子序列

求一个数组的最长递减子序列

如{9,4,3,2,5,4,3,2}的最长递减子序列为{9,5,4,3,2}

思路:动态规划

构建与原数组同等容量的辅助数组dp,记录以每个元素结束的最大序列的长度,如dp[0]=1,如果dp[i]<dp[i-1],则dp[i]=dp[i-1]+1,否则dp[i]=1;循环可求出dp数组。最终根据求出的dp数组最大值以及该值的索引按需截取子串即可!
最长递增子序列反推即可!

javascript 复制代码
line = '9 5 4 3 2 5 4 3 1';
line = line.split(' ');
let n = line.length;
let res = [];
let dp = [];
dp[0] = 1;
//构造动态数组记录截止每个元素时的递减长度
for (let i = 1; i < n; i++) {
    if (line[i] < line[i - 1]) {
        dp[i] = dp[i - 1] + 1;
    } else {
        dp[i] = 1;
    }
}
//console.log('dp', dp);
let max = dp[0];//
let tag = 0;
//找出截止该元素最长递减子列表长度及及其所在位置索引
for (let i = 1; i < n; i++) {
    if (max <= dp[i]) {
        max = Math.max(max, dp[i]);
        //找出最长递减子列表长度的结束位置
        tag = i;
    }
}
//console.log('max', max);
//用substr截取即可,tag+1是为了防止出现-1
res = line.join('').substr(tag + 1 - max, max);
// res=line.slice(tag-max,tag);
//console.log('tag', tag);
console.log('res', res);
相关推荐
爱睡D小猪几秒前
vue文本高亮处理
前端·javascript·vue.js
paopaokaka_luck1 分钟前
基于Spring Boot+Vue的多媒体素材管理系统的设计与实现
java·数据库·vue.js·spring boot·后端·算法
开心工作室_kaic3 分钟前
ssm102“魅力”繁峙宣传网站的设计与实现+vue(论文+源码)_kaic
前端·javascript·vue.js
放逐者-保持本心,方可放逐4 分钟前
vue3 中那些常用 靠copy 的内置函数
前端·javascript·vue.js·前端框架
IT古董4 分钟前
【前端】vue 如何完全销毁一个组件
前端·javascript·vue.js
Henry_Wu0016 分钟前
从swagger直接转 vue的api
前端·javascript·vue.js
奋飞安全7 分钟前
初试js反混淆
开发语言·javascript·ecmascript
Tmbcan10 分钟前
zkw 线段树-原理及其扩展
数据结构·zkw 线段树
视觉小萌新17 分钟前
VScode+opencv——关于opencv多张图片拼接成一张图片的算法
vscode·opencv·算法
2301_8017609318 分钟前
数据结构--PriorityQueue
数据结构