给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。
子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。
dp数组的含义:到下标i为止,以nums[i]结尾的最长递增子序列的长度。
以序列 0 1 0 3 2 为例
0 | 1 | 0 | 3 | 2 |
1 | 2 | |||
1 | 2 | 1 | ||
1 | 2 | 1 | 3 | |
1 | 2 | 1 | 3 | 3 |
class Solution {
public:
int lengthOfLIS(vector<int>& nums) {
if(nums.size()==1) return 1;
//dp[i]表示到下标i为止,以nums[i]结尾的最长递增子序列长度
vector<int> dp(nums.size(),1);
int result=0;
for(int i=1;i<nums.size();i++){
for(int j=0;j<i;j++){
if(nums[i]>nums[j]) dp[i]=max(dp[i],dp[j]+1);
}
result=max(result,dp[i]);
}
return result;
}
};