力扣300. 最长递增子序列

动态规划

  • 思路:
    • 假设 dp[i] 为前 i 个元素构成的最长递增子序列的个数,包含 nums[i];
    • 则 dp[i] 构成序列上一个元素 nums[j] 构成最长递增子序列 dp[j],则 dp[i] = dp[j] + 1;
    • 如果动态取 j ∈ [0, i - 1],则选取其中最长递增子序列值中最大的,其值 + 1 来更新 dp[i] 的值;
cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        int size = (int)nums.size();
        if (size == 0) {
            return 0;
        }

        std::vector<int> dp(size, 0);
        for (int i = 0; i < size; ++i) {
            dp[i] = 1;
            for (int j = 0; j < i; ++j) {
                if (nums[j] < nums[i]) {
                    dp[i] = std::max(dp[i], dp[j] + 1);
                }
            }
        }

        return *std::max_element(dp.begin(), dp.end());
    }
};
相关推荐
网域小星球7 分钟前
C 语言从 0 入门(二十一)|typedef 类型重定义:简化复杂类型,代码更清爽
c语言·算法·类型重定义·结构体简化·函数指针简化
XWalnut11 分钟前
LeetCode刷题 day10
数据结构·算法·leetcode
测试秃头怪37 分钟前
Python+selenium搭建Web自动化测试框架
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
programhelp_1 小时前
Amazon OA 2026 高频题型拆解 + 速通攻略
数据结构·算法
moonsea02031 小时前
2026.4.14
数据结构·算法·图论
x_xbx1 小时前
LeetCode:42. 接雨水
算法·leetcode·职场和发展
lixinnnn.1 小时前
01BFS:小明的游戏
算法
falldeep1 小时前
Claude Code源码分析
人工智能·算法·机器学习·强化学习
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.04.14 题目:2463.最小移动距离
笔记·算法·leetcode
feng_you_ying_li1 小时前
C++11可变模板参数,包扩展,emplace系列和push系列的区别
前端·c++·算法