LeetCode 300. 最长递增子序列

LeetCode 300. 最长递增子序列,第1张

LeetCode 300. 最长递增子序列


动态规划

const int N = 2510;
class Solution {
public:
    int f[N];
    int lengthOfLIS(vector<int>& nums) {
        int n = nums.size();
        int res = 0;
        for(int i = 0; i < n; i ++)
        {
            f[i] = 1;
            for(int j = 0; j < i; j ++)
                if(nums[i] > nums[j])
                    f[i] = max(f[i], f[j] + 1);
            res = max(res, f[i]);
        }
        return res;
    }
};

DP + 二分

class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        if(nums.size() <= 1) return nums.size();
        vector<int> f;
        for(auto &n : nums)
        {
            auto idx = lower_bound(f.begin(), f.end(), n) - f.begin(); //找到大于等于 n 的位置
            if(idx >= f.size()) //如果不存在
                f.push_back(n);
            else
                f[idx] =  min(f[idx], n); //存在贪心取最小
        }
        return f.size();
    }
};

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1354004.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-14
下一篇2022-06-14

发表评论

登录后才能评论

评论列表(0条)

    保存