*长上升子序列(JS实现)

\
1 题目
给定一个无序的整数数组,找到其中*长上升子序列的长度。
示例:
输入: [10,9,2,5,3,7,101,18]
输出: 4
解释: *长的上升子序列是 [2,3,7,101],它的长度是 4。
说明:
可能会有多种*长上升子序列的组合,你只需要输出对应的长度即可。
你算法的时间复杂度应该为 O(n2) 。
进阶: 你能将算法的时间复杂度降低到 O(n log n) 吗?

链接:https://leetcode-cn.com/problems/longest-increasing-subsequence

2 思路
这道题明显根据题意就知道应该用动态规划来做,注意题意,这里是子序列并不是要求连续的,设d[i]为0…i元素之间*大上升子序列长度,状态转移方程为 d[i+1] = max(d[0…i]) + 1

3代码
/**
* @param {number[]} nums
* @return {number}
*/
var lengthOfLIS = function(nums) {
if (nums.length < 2) return nums.length;
const d = [1];

let maxAns = 1;
for (let i=1; i<nums.length; i++) {
let len = 0;
for (let j=0;j<d.length;j++) {
if (nums[i] > nums[j]) {
len = Math.max(len, d[j]);
}
}
d[i] = len + 1;
maxAns = Math.max(maxAns, d[i])
}

return maxAns;
};