题目:
代码(首刷看解析 2024年2月29日):
class Solution {
public:
int lengthOfLIS(vector<int>& nums) {
int n = nums.size();
if (n <= 1) return 1;
vector<int> dp(n, 1);
int res = 0;
for (int i = 1; i < n; ++i) {
for(int j = 0; j < i; ++j) {
if (nums[i] > nums[j])
dp[i] = max(dp[i], dp[j] + 1);
}
if (dp[i] > res) res = dp[i];
}
return res;
}
};
代码(二刷看解析 2024年3月10日)
class Solution {
public:
int lengthOfLIS(vector<int>& nums) {
if (nums.empty()) return 0;
// 关键思路: 对于每个i,遍历 0 ~ i之间的数,若 < nums[i] 考虑更新dp[i]
int n = nums.size();
vector<int> dp(n, 1);
int result = 1;
for (int i = 0; i < n; ++i) {
for (int j = 0; j < i; ++j) {
if (nums[j] < nums[i]) {
dp[i] = max(dp[i], dp[j] + 1);
result = max(result, dp[i]);
}
}
}
return result;
}
};