蓝桥杯每日一练——最长递增子序列(动态规划)

最长递增子序列https://leetcode-cn.com/problems/longest-increasing-subsequence/

题目描述:

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 

蓝桥杯每日一练——最长递增子序列(动态规划)_第1张图片

class Solution {
public:
    int lengthOfLIS(vector& nums) {
        int n = (int)nums.size();
        if (n == 0) {
            return 0;
        }
        vector dp(n, 0);
        for (int i = 0; i < n; ++i) {
            dp[i] = 1;
            for (int j = 0; j < i; ++j) {
                if (nums[j] < nums[i]) {
                    dp[i] = max(dp[i], dp[j] + 1);
                }
            }
        }
        return *max_element(dp.begin(), dp.end());
    }
};

蓝桥杯每日一练——最长递增子序列(动态规划)_第2张图片

你可能感兴趣的:(蓝桥杯备战,算法,数据结构,蓝桥杯)