美文网首页
LeetCode300——最长递增子序列

LeetCode300——最长递增子序列

作者: random_walk | 来源:发表于2021-07-26 23:50 被阅读0次

题目描述

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。
子序列是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-increasing-subsequence

动态规划

定义转移矩阵和转移规则,设dp[i]是以数组第i个元素结尾的最长递增子序列的长度,那么可以找到dp[i]与之前的元素关系是,如果nums[i]大于nums[j]j<i,则dp[i] = max{dp[j] + 1},j < i。复杂度O(n^2)
代码

class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        int n = nums.size();
        vector<int> dp(n, 1);

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

        return *std::max_element(dp.begin(), dp.end());

    }
};

贪心+二分

主要思路是直观的想法是要让递增数组足够长,那么需要前面的数尽量小,去维护这样一个递增的数组。通过遍历给定的整数数组,如果当前的元素比维护数组的元素大,那么肯定可以添加进去,如果不是,说明维护数组有的元素比当前的元素大,需要做一个替换用当前元素覆盖掉第一个比它大的元素(这样做的话后续递增序列才有可能更长,即使并没有更长,这个覆盖操作也并没有副作用,当然这个覆盖操作可能会让最终的结果数组值并不是最终的递增序列值),这样最后得到的维护数组长度即为目标长度,证明可以看问题讨论区,时间复杂度O(nlogn)

class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        vector<int> ans;
        for (int i = 0; i < nums.size(); i++) {
            if (i == 0) {
                ans.push_back(nums[i]);
            }
            else {
                auto it = std::lower_bound(ans.begin(), ans.end(), nums[i]);
                if (it == ans.end()) ans.push_back(nums[i]);
                else *it = nums[i];
            }
        }
        return ans.size();

    }
};

相关题目

题目 难度 思路
334. 递增的三元子序列 中等 简单
712. 两个字符串的最小ASCII删除和 中等 待做
673. 最长递增子序列的个数 中等 待做
646. 最长数对链 中等 待做
354. 俄罗斯套娃信封问题 困难 待做

相关文章

  • LeetCode300——最长递增子序列

    题目描述 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。子序列是由数组派生而来的序列,删除(或不...

  • LeetCode-300-最长递增子序列

    LeetCode-300-最长递增子序列 300. 最长递增子序列[https://leetcode-cn.com...

  • 动态规划-LIS

    LIS 最长递增子序列 如 x 的 最长递增子序列长度为5 方法一 对 x 排序(升序)生成 x_sorted 对...

  • LeetCode 300. Longest Increasing

    问题描述 给定一个未排序的整数数组,找出最长的递增子序列。 栗子: 注意: 可能存在多种最长递增子序列的组合,只需...

  • 最长递增子序列

    问题描述 求最长递增子序列的长度 分析 主要是确定状态,F[i]表示以ai 结束的最长递增子序列长度,F[i]=m...

  • 经典DP问题合集

    一、上台阶问题 二、矩阵最小路径和 三、最长递增子序列 四、最长公共子序列 五、背包问题

  • 动态规划常见面试题

    子序列类型编辑距离 最长递增子序列 最大子数组 最长公共子序列 背包问题0-1背包问题 子集背包问题 完全背包问题...

  • 最长递增子序列: 动态规划和LCS(最长公共子序列)

    最长递增子序列: 动态规划和LCS(最长公共子序列)子序列和子串的区别:子序列不连续,字串连续。这个题两种解法 动...

  • 最长递增子序列

    //Given an unsorted array of integers, find the length of...

  • 最长递增子序列

    通常有4个步骤来设计动态规划算法: 1.刻画一个最优解的结构特征。 2.递归地定义最优解的值。 3.计算最优解的值...

网友评论

      本文标题:LeetCode300——最长递增子序列

      本文链接:https://www.haomeiwen.com/subject/varnmltx.html