力扣HOT100之动态规划:300. 最长递增子序列

这道题之前刷代码随想录的时候也刷过,现在又给忘完了。自己尝试着写了一下,发现怎么写都写不对,直接去看视频了。。我自己写的时候的定义是:考虑下标0 ~ i范围内索赔能取到的最长严格递增子序列的长度,后面发现在写递推公式的时候怎么都写不对,这道题的dp数组的含义为:以nums[i]为结尾的情况下,其最长严格递增子序列的长度。那么递推公式就很好想了,在以nums[i]为结尾的情况下,我们从头开始搜索,如果遇到nums[j] < nums[i]的情况,则说明nums[i]可以作为以nums[j]结尾的子序列的下一个元素,我们需要对比dp[j] + 1dp[i]之间的大小关系,取较大值作为新的dp[i]。遍历顺序也很好想,二重循环都是从小到大遍历的。下面写下递归五部曲:

1.确定dp[i]的含义:以nums[i]为结尾的情况下,其最长严格递增子序列的长度

2.确定递推公式 dp[i] = max(dp[j] + 1, dp[i]) (只有nums[i] > nums[j]才会触发)

3.dp数组初始化 dp[0] = 1

4.确定遍历顺序:从左往右遍历

5.打印数组(省略)

值得注意的是,我们最终要返回的不一定是dp[s.size() - 1],因为最后一个元素不一定是最大元素,最大元素可能在前面的任意位置,例如数组[0, 1, 2, 3, 4, 5, 1],最大长度在元素5这里产生,我们需要用一个额外变量result来维护最大长度。

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        //1.确定dp[i]的含义:以nums[i]为结尾的情况下,其最长严格递增子序列的长度
        //2.确定递推公式  dp[i] = max(dp[j] + 1, dp[i]) (只有nums[i] > nums[j]才会触发)
        //3.dp数组初始化 dp[0] = 1  
        //4.确定遍历顺序:从左往右遍历
        //5.打印数组(省略)
        int n = nums.size();
        vector<int> dp(n, 1);
        int result = 1;   //用于记录整个数组中的最长子序列的长度
        //初始化
        dp[0] = 1;
        for(int i = 1; i < n; i++){   //逐渐扩大数组范围
            for(int j = 0; j < i; j++){   //内循环则确定nums[i]为结尾的情况下所能取到的最长严格递增子序列的长度
                if(nums[i] > nums[j])  //nums[i]可以作为以nums[j]结尾的子序列的下一个元素时
                    dp[i] = max(dp[j] + 1, dp[i]);
            }
            result = max(result, dp[i]);  //维护最长严格递增子序列的长度
        }
        return result;
    }
};
相关推荐
阳洞洞1 小时前
79. Word Search
leetcode·回溯
kingmax542120081 小时前
【洛谷P9303题解】AC- [CCC 2023 J5] CCC Word Hunt
数据结构·c++·算法·广度优先
白熊1882 小时前
【机器学习基础】机器学习入门核心算法:XGBoost 和 LightGBM
人工智能·算法·机器学习
bai_lan_ya2 小时前
数据结构-排序-排序的七种算法(2)
数据结构·算法·排序算法
全域智图4 小时前
元胞自动机(Cellular Automata, CA)
人工智能·算法·机器学习
珂朵莉MM4 小时前
2022 RoboCom 世界机器人开发者大赛-本科组(省赛)解题报告 | 珂学家
人工智能·算法·职场和发展·深度优先·图论
独家回忆3644 小时前
每日算法-250601
数据结构·算法
YONYON-R&D4 小时前
DEEPSEEK帮写的STM32消息流函数,直接可用.已经测试
算法·消息流
Steve lu5 小时前
回归任务损失函数对比曲线
人工智能·pytorch·深度学习·神经网络·算法·回归·原力计划
蒙奇D索大6 小时前
【数据结构】图论核心算法解析:深度优先搜索(DFS)的纵深遍历与生成树实战指南
数据结构·算法·深度优先·图论·图搜索算法