LeetCode百题【最长递增子序列】
题目描述
给你一个整数数组 nums
,找到其中最长严格递增子序列的长度。
子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7]
是数组 [0,3,1,6,2,2,7]
的子序列。
示例 1:
1 |
|
示例 2:
1 |
|
示例 3:
1 |
|
提示:
1 <= nums.length <= 2500
-10^4 <= nums[i] <= 10^4
进阶:
- 你能将算法的时间复杂度降低到
O(n log(n))
吗?
解法
动态规划
- 定义
dp[i]
为考虑前 i个元素,以第 i 个数字结尾的最长上升子序列的长度 - 那么有动态转移方程
$$
dp[i]=max(dp[j])+1,其中0≤j<i且num[j]<num[i]
$$- 整个数组的最长上升子序列即所有
dp[i]
中的最大值
- 定义
1 |
|
- 时间复杂度:O(n^2)
来源:力扣(LeetCode)
链接:300. 最长递增子序列 - 力扣(LeetCode)
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 漫漫长夜!